diff --git a/.codespellrc b/.codespellrc index 5782ae4..409cb11 100644 --- a/.codespellrc +++ b/.codespellrc @@ -1,7 +1,7 @@ [codespell] # Ref: https://github.com/codespell-project/codespell#using-a-config-file -skip = .git*,*.svg,package-lock.json,*.css,*-min.*,.codespellrc,*.bundle.*,*.map +skip = .git*,*.svg,package-lock.json,*.css,*-min.*,.codespellrc,*.bundle.*,*.map, *.js check-hidden = true -# ignore-regex = +# ignore-regex = # some favorite albeit unfortunate variable names ignore-words-list = te diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 3668fdd..73bc890 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -14,4 +14,3 @@ repos: rev: v2.3.0 hooks: - id: codespell - diff --git a/neuvue_project/neuvue/settings.py b/neuvue_project/neuvue/settings.py index 949e73f..cfdd1f4 100644 --- a/neuvue_project/neuvue/settings.py +++ b/neuvue_project/neuvue/settings.py @@ -9,6 +9,7 @@ For the full list of settings and their values, see https://docs.djangoproject.com/en/3.2/ref/settings/ """ + import os # Build paths inside the project like this: BASE_DIR / 'subdir'. @@ -24,6 +25,8 @@ # SECURITY WARNING: don't run with debug turned on in production! DEBUG = False +SITE_ID = 2 + ALLOWED_HOSTS = [ ".neuvue.io", ".elasticbeanstalk.com", @@ -242,4 +245,7 @@ mimetypes.add_type("application/javascript", ".js", True) -STATIC_NG_FILES = os.listdir(os.path.join(BASE_DIR, "workspace", "static", "workspace")) +STATIC_NG_FILES = os.listdir( + os.path.join(BASE_DIR, "workspace", "static", "workspace") +) + os.listdir(os.path.join(BASE_DIR, "workspace", "static", "spelunker-workspace")) +# STATIC_NG_FILES = os.listdir(os.path.join(BASE_DIR, "workspace", "static", "workspace-spelunker")) diff --git a/neuvue_project/neuvue/urls.py b/neuvue_project/neuvue/urls.py index de107ea..8ac2a15 100644 --- a/neuvue_project/neuvue/urls.py +++ b/neuvue_project/neuvue/urls.py @@ -47,6 +47,11 @@ path("tasks/", TaskView.as_view(), name="tasks"), path("getting-started/", GettingStartedView.as_view(), name="getting-started"), path("workspace/", WorkspaceView.as_view(), name="workspace"), + path( + "spelunker-workspace/", + WorkspaceView.as_view(), + name="spelunker-workspace", + ), path("admin/", admin.site.urls), path("__debug__/", include("debug_toolbar.urls")), path("accounts/", include("allauth.urls")), diff --git a/neuvue_project/neuvueDB.sqlite3 b/neuvue_project/neuvueDB.sqlite3 index 8c6c3df..016babc 100644 Binary files a/neuvue_project/neuvueDB.sqlite3 and b/neuvue_project/neuvueDB.sqlite3 differ diff --git a/neuvue_project/templates/about.html b/neuvue_project/templates/about.html index 0e8fa7d..b7fc105 100644 --- a/neuvue_project/templates/about.html +++ b/neuvue_project/templates/about.html @@ -82,7 +82,7 @@

Collaborators

Contact Us

- We'd love to hear from you! Reach out at info@neuvue.io with questions or if you are interested in collaborating with us. + We'd love to hear from you! Reach out at info@bossdb.org with questions or if you are interested in collaborating with us.

diff --git a/neuvue_project/templates/inspect.html b/neuvue_project/templates/inspect.html index 81b0dcf..7712dff 100644 --- a/neuvue_project/templates/inspect.html +++ b/neuvue_project/templates/inspect.html @@ -101,7 +101,11 @@

Inspect Task

- +{% if ng_host == "spelunker" %} + +{% else %} + +{% endif %} {% endif%} @@ -111,18 +115,41 @@

Inspect Task

+ +{% if ng_host == "spelunker" %} + +{% else %} +{% endif %} + + + +

This page is a placeholder for Keycloak redirection.

+

+ + diff --git a/neuvue_project/workspace/static/spelunker-workspace/compresso.0d45ed2ede4537f701f8.wasm b/neuvue_project/workspace/static/spelunker-workspace/compresso.0d45ed2ede4537f701f8.wasm new file mode 100644 index 0000000..748ebb3 Binary files /dev/null and b/neuvue_project/workspace/static/spelunker-workspace/compresso.0d45ed2ede4537f701f8.wasm differ diff --git a/neuvue_project/workspace/static/spelunker-workspace/google_oauth2_redirect.html b/neuvue_project/workspace/static/spelunker-workspace/google_oauth2_redirect.html new file mode 100644 index 0000000..d1a777d --- /dev/null +++ b/neuvue_project/workspace/static/spelunker-workspace/google_oauth2_redirect.html @@ -0,0 +1,21 @@ + + + + Google oauth redirect + + + +

Google authentication successful.

+

+ + diff --git a/neuvue_project/workspace/static/spelunker-workspace/index.html b/neuvue_project/workspace/static/spelunker-workspace/index.html new file mode 100644 index 0000000..6d30448 --- /dev/null +++ b/neuvue_project/workspace/static/spelunker-workspace/index.html @@ -0,0 +1 @@ +Neuroglancer \ No newline at end of file diff --git a/neuvue_project/workspace/static/spelunker-workspace/libpng.4e1203f419dab329d4f3.wasm b/neuvue_project/workspace/static/spelunker-workspace/libpng.4e1203f419dab329d4f3.wasm new file mode 100644 index 0000000..06c63a5 Binary files /dev/null and b/neuvue_project/workspace/static/spelunker-workspace/libpng.4e1203f419dab329d4f3.wasm differ diff --git a/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.css b/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.css new file mode 100644 index 0000000..f0bf9d3 --- /dev/null +++ b/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.css @@ -0,0 +1,115 @@ +.neuroglancer-annotation-rendering-tab{display:flex;flex-direction:column;overflow-y:auto}.neuroglancer-annotation-rendering-tab .neuroglancer-shader-code-widget{flex-shrink:0}.neuroglancer-annotation-shader-property-list{max-height:8em;overflow:auto;flex-shrink:0}.neuroglancer-annotation-shader-property{white-space:pre;font-family:monospace;font-size:medium}.neuroglancer-annotation-shader-property-type{color:#c6c;margin-right:1ch}.neuroglancer-annotation-shader-property-identifier{user-select:text}.neuroglancer-annotation-shader-property-identifier:after{content:"()";color:#999}.neuroglancer-annotation-tag-property-type{color:#999}.neuroglancer-tag-list>div{display:grid}.neuroglancer-add-tag-control>input,.neuroglancer-tag-list-entry>input{background-color:#151515;color:#fff;font-family:monospace;font-size:medium;border:2px solid #333;padding:2px;outline:0px}.neuroglancer-tags-container{display:flex;flex-direction:column;flex:1;align-items:stretch}.neuroglancer-tag-list-outer{position:relative;margin:2px 0 0;padding:0;overflow-y:auto;height:0px;flex:1;flex-basis:0px;min-height:0px}.neuroglancer-tag-list-entry{display:grid;grid-template-columns:min-content auto min-content;align-items:center;white-space:nowrap;padding:2px 20px 2px 0}.neuroglancer-tag-list-entry.add .neuroglancer-tool-button{visibility:hidden}.neuroglancer-tag-list-entry:hover .neuroglancer-tag-list-entry-delete{visibility:visible}.neuroglancer-tag-list-entry .neuroglancer-tag-list-entry-delete{visibility:hidden}/** + * @license + * Copyright 2024 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */.neuroglancer-transfer-function-panel{height:60px;border:1px solid #666;margin-top:5px}.neuroglancer-transfer-function-color-picker{text-align:right}.neuroglancer-transfer-function-widget-bound{background-color:transparent;border-color:transparent;box-shadow:none;border:0;margin:0;font-family:monospace;font-size:medium;color:#0ff}.neuroglancer-transfer-function-window-bounds{display:flex;justify-content:space-between}.neuroglancer-invlerp-cdfpanel{height:50px;cursor:ew-resize}.neuroglancer-invlerp-cdfpanel,.neuroglancer-invlerp-legend-panel{border:1px solid #666}.neuroglancer-invlerp-legend-panel{height:15px}.neuroglancer-invlerp-widget-bound{background-color:transparent;border-color:transparent;box-shadow:none;border:0;margin:0;font-family:monospace;font-size:medium}.neuroglancer-invlerp-widget-window-bound{color:#0ff}.neuroglancer-invlerp-widget-range-bound{color:#fff}.neuroglancer-invlerp-widget-bounds{display:flex}.neuroglancer-invlerp-widget-range-spacer{flex:1;text-align:center}.neuroglancer-invlerp-widget-window-bounds{justify-content:space-between}.neuroglancer-icon{display:inline-flex;text-decoration:none;align-self:center;white-space:nowrap;padding-left:2px;padding-right:2px;min-width:18px;min-height:18px;border-radius:20%;align-items:center;justify-content:center;color:#fff;font:12px sans-serif;cursor:pointer;font-weight:900;margin-left:1px;margin-right:1px;user-select:none}.neuroglancer-icon svg{width:16px;height:16px;fill:transparent;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.neuroglancer-icon:hover{background-color:#db4437}.neuroglancer-icon-hover:not(:hover) svg:last-child{display:none}.neuroglancer-icon-hover:hover svg:first-child{display:none}.neuroglancer-tab-view{display:flex;flex-direction:column}.neuroglancer-tab-view-bar{display:block;background-color:#333;border-bottom:1px solid white}.neuroglancer-tab-label{display:inline-block;border-top:1px solid transparent;border-left:1px solid transparent;border-right:1px solid transparent;border-bottom:none;margin-right:4px;padding-top:1px;padding-left:2px;padding-right:2px;font:10pt sans-serif;font-weight:700;cursor:pointer}.neuroglancer-tab-label:hover{color:#daa520}.neuroglancer-tab-label.neuroglancer-selected-tab-label{background-color:#000;border-top:1px solid white;border-left:1px solid white;border-right:1px solid white;border-bottom:1px solid black;padding-bottom:1px;margin-bottom:-1px}.neuroglancer-stack-view{display:contents}.neuroglancer-tab-view>.neuroglancer-stack-view>.neuroglancer-tab-content{flex:1;flex-basis:0px;height:0px;min-height:0px;padding:2px}.neuroglancer-position-widget{display:inline-flex;align-items:center}.neuroglancer-position-widget input:disabled{pointer-events:none}.neuroglancer-position-widget .neuroglancer-copy-button:first-child{display:none}.neuroglancer-position-dimension-coordinate,.neuroglancer-position-dimension-name,.neuroglancer-position-dimension-scale{background-color:transparent;border-color:transparent;box-shadow:none;border:0;margin:0;font-family:monospace;font-size:medium}.neuroglancer-position-dimension[data-coordinate-array=valid] .neuroglancer-position-dimension-scale{display:none}.neuroglancer-position-dimension[data-coordinate-array=invalid] .neuroglancer-position-dimension-scale{text-decoration-line:underline;text-decoration-style:wavy;text-decoration-color:red}.neuroglancer-position-dimension-coordinate{color:#fff;text-align:right}.neuroglancer-position-widget input:invalid,.neuroglancer-position-widget input::placeholder,.neuroglancer-position-widget input[data-is-valid=false]{text-decoration:solid underline red}.neuroglancer-position-widget *:focus{outline:0px}.neuroglancer-position-dimension+.neuroglancer-position-dimension{margin-left:1ch}.neuroglancer-position-dimension[data-dropdown-visible=true]:after{content:"";display:block;left:0;right:0;bottom:-1px;position:absolute;border-bottom:1px solid black;z-index:100;height:0px}.neuroglancer-position-dimension-dropdown,.neuroglancer-position-dimension-coordinate-dropdown{position:absolute;min-width:calc(100% + 2px);border:1px solid #aaa;box-sizing:border-box;padding:2px;left:-1px;z-index:100;background-color:#000}.neuroglancer-position-dimension-coordinate-dropdown{display:flex;flex-direction:column;overflow-y:auto}.neuroglancer-dimension-dropdown-coordinate-entry{display:flex;flex-direction:row;justify-content:space-between}.neuroglancer-dimension-dropdown-coordinate-entry:hover{background-color:#333}.neuroglancer-dimension-dropdown-coordinate-label{width:var(--neuroglancer-coordinate-label-width);color:#0ff}.neuroglancer-position-dimension-dropdown:focus,.neuroglancer-position-dimension-coordinate-dropdown:focus{outline:0px}.neuroglancer-position-dimension:focus-within,.neuroglancer-position-dimension[data-dropdown-visible=true]{border:1px solid #aaa;background-color:#000}.neuroglancer-position-dimension{border:1px solid transparent;position:relative;display:inline-block;white-space:nowrap}.neuroglancer-position-dimension-name{color:#ff6;padding-left:2px}.neuroglancer-position-dimension-scale-container[data-is-empty=false]:before{content:"(";color:#aaa}.neuroglancer-position-dimension-scale-container[data-is-empty=false]:after{content:")";color:#aaa}.neuroglancer-position-dimension-scale-container[data-is-empty=false]{margin-right:5px}.neuroglancer-position-dimension-scale{color:#bbb}.neuroglancer-position-dimension-scale-container{margin-right:2px;margin-left:4px}.neuroglancer-mouse-position-widget{margin-left:1ch;vertical-align:center;font-family:monospace;font-size:medium;color:orange;white-space:pre}.neuroglancer-position-dimension-coordinate-label{display:inline-block;color:#0ff}.neuroglancer-position-dimension-coordinate-label:not(:empty):before{content:"[";color:#aaa}.neuroglancer-position-dimension-coordinate-label:not(:empty):after{content:"]";color:#aaa}.neuroglancer-position-dimension-playback{font-family:sans-serif;font-size:10pt;display:flex;flex-direction:column}.neuroglancer-position-dimension-playback .neuroglancer-number-input{display:flex;flex-direction:row;align-items:center;margin-bottom:2px}.neuroglancer-position-dimension-playback input[type=text]{background-color:#ffffff4d;color:#fff;border:0px;font-family:monospace;width:8ch;text-align:right}.neuroglancer-position-dimension-playback select{align-self:center}.neuroglancer-position-dimension>.neuroglancer-icon{min-width:14px;min-height:14px;position:relative;top:1px}.neuroglancer-position-dimension>.neuroglancer-icon svg{width:12px;height:12px}.neuroglancer-position-tool{background-color:#474747}.neuroglancer-position-dimension-playback-header{display:flex;flex-direction:row;align-items:center}#statusContainer{position:absolute;bottom:0;z-index:100;background-color:gray;color:#fff;margin:0;padding:0;font:10pt sans-serif}#statusContainer li{width:100vw;max-height:25vh;overflow-y:auto}.neuroglancer-status-header{display:inline-block;font:10pt sans-serif;font-weight:700;background-color:#333;padding:2px}#statusContainerModal{pointer-events:none;position:absolute;z-index:100;color:#fff;margin:0;padding:0;font:10pt sans-serif;display:grid;align-content:center;justify-content:center;height:100vh;width:80vw;left:10vw;grid-row-gap:10px}#statusContainerModal>div{pointer-events:initial;position:relative;background-color:gray;padding:30px 20px 20px}#statusContainerModal>div>div:first-child{position:absolute;top:4px;right:4px;margin:0;padding:0}#statusContainerModal li{display:block}.neuroglancer-tool-key-binding{display:inline-block;color:#0ff;font:9pt monospace;white-space:pre}.neuroglancer-tool-key-binding:hover{outline:1px solid #fff}.neuroglancer-tool-key-binding:before{content:"["}.neuroglancer-tool-key-binding:after{content:"]"}.neuroglancer-tool-key-binding:before,.neuroglancer-tool-key-binding:after{color:#999}.neuroglancer-tool-button{display:inline-flex;flex-direction:row}#statusContainer li.neuroglancer-tool-status{max-height:50vh}.neuroglancer-tool-status-bindings{background-color:#333;user-select:none}.neuroglancer-tool-status-content{display:flex;flex-direction:row}.neuroglancer-tool-status-header-container{background-color:#555;width:min-content;padding:3px;display:flex;flex-direction:row;align-items:center}.neuroglancer-tool-status-header{align-self:center}.neuroglancer-tool-status-body{flex:1;padding:2px}.neuroglancer-checkbox-icon.light-background[data-checked=true]{background-color:#00000080}.neuroglancer-checkbox-icon.dark-background[data-checked=true]{background-color:#fff3}.neuroglancer-position-dimension-plot{display:grid;overflow:hidden;position:relative}.neuroglancer-position-dimension-plot[data-orientation=column]{grid-template-areas:"labels . graph";grid-template-rows:1fr;grid-template-columns:0fr 3px 0fr}.neuroglancer-position-dimension-plot[data-orientation=row]{grid-template-areas:"labels" "." "graph";grid-template-columns:minmax(0px,1fr);grid-template-rows:0fr 3px 0fr}.neuroglancer-position-dimension-plot-lowerbound,.neuroglancer-position-dimension-plot-upperbound,.neuroglancer-position-dimension-plot-hoverposition{grid-area:labels;font-family:monospace;font-size:medium;user-select:none}.neuroglancer-position-dimension-plot[data-orientation=column] :is(.neuroglancer-position-dimension-plot-lowerbound,.neuroglancer-position-dimension-plot-upperbound,.neuroglancer-position-dimension-plot-hoverposition){text-align:right}.neuroglancer-position-dimension-plot[data-orientation=row] :is(.neuroglancer-position-dimension-plot-lowerbound,.neuroglancer-position-dimension-plot-upperbound,.neuroglancer-position-dimension-plot-hoverposition){max-width:max-content}.neuroglancer-position-dimension-plot>canvas{grid-area:graph}.neuroglancer-position-dimension-plot[data-orientation=column]>canvas{margin-top:.5em;margin-bottom:.5em}.neuroglancer-segmentation-rendering-tab{display:flex;flex-direction:column;overflow-y:auto}.neuroglancer-segmentation-rendering-tab .neuroglancer-shader-code-widget{height:6em}.neuroglancer-segmentation-dropdown-skeleton-shader-header{display:flex;flex-direction:row;align-items:center}.neuroglancer-segmentation-layer-skeleton-shader-overlay .neuroglancer-shader-code-widget{width:80vw;height:80vh}.neuroglancer-segment-list-entry{display:flex;flex-direction:row;width:min-content;min-width:100%;background-color:#000;align-items:start}.neuroglancer-segment-list-entry.neuroglancer-segment-list-entry-double-line{display:inline-flex;min-width:initial;background-color:initial}.neuroglancer-segment-list-entry[data-selected=true],.neuroglancer-selection-details-segment[data-selected=true]{background-color:#222}.neuroglancer-segment-list-entry-copy-container{display:flex;flex-direction:column}.neuroglancer-segment-list-entry-id-container{order:1;align-self:center}.neuroglancer-segment-list-entry-id,.neuroglancer-selection-details-segment-id{display:block;font-family:monospace;font-size:medium;flex-shrink:0;text-align:right;color:#000;background-color:#fff;user-select:text;width:var(--neuroglancer-segment-list-width)}.neuroglancer-segment-list .neuroglancer-segment-list-entry-sticky{position:sticky;left:0}.neuroglancer-segment-list-entry-sticky{white-space:nowrap;flex-direction:row;align-items:start;background-color:inherit;display:flex}.neuroglancer-segment-list-entry.neuroglancer-segment-list-header .neuroglancer-segment-list-entry-star,.neuroglancer-segment-list-entry.neuroglancer-segment-list-header:hover .neuroglancer-segment-list-entry-copy{visibility:hidden}.neuroglancer-segment-list-entry-extra-property{padding-left:8px;flex-shrink:0;text-align:right;user-select:text}.neuroglancer-selection-details-segment-description,.neuroglancer-selection-details-segment-property{font-family:sans-serif;font-size:small}.neuroglancer-selection-details-segment-property{display:flex;flex-direction:row}.neuroglancer-selection-details-segment-property-name{user-select:text;font-style:italic}.neuroglancer-selection-details-segment-property-value{text-align:right;flex:1}.neuroglancer-segmentation-toolbox{display:inline-block}.neuroglancer-segmentation-toolbox .neuroglancer-tool-button+.neuroglancer-tool-button{margin-left:1em}.neuroglancer-segment-list-entry .neuroglancer-color-widget{border:none;border-color:transparent;appearance:none;background-color:transparent;padding:0;margin:0 0 0 3px;height:19px;width:20px}.neuroglancer-segment-list-entry .neuroglancer-color-widget.overridden{background-color:#fff}.neuroglancer-layer-options-control-container .neuroglancer-layer-control-label-container{margin-right:auto}.neuroglancer-layer-control-label-container{white-space:nowrap}.neuroglancer-layer-control-label{display:flex;flex-direction:row;align-items:center}.neuroglancer-layer-control-label-text-container{display:flex;flex-direction:row;align-items:start}.neuroglancer-layer-control-container{margin-top:1.5px;margin-bottom:1.5px;display:flex;flex-direction:row;align-items:center}.neuroglancer-layer-control-control{flex:1;margin-left:5px;max-width:500px}select.neuroglancer-layer-control-control,input[type=checkbox].neuroglancer-layer-control-control,input[type=color].neuroglancer-layer-control-control{flex:initial}.range-slider{display:flex;flex-direction:row;white-space:nowrap;justify-content:flex-end}.range-slider input[type=range]{background:transparent;flex-basis:0px}.range-slider input[type=number]{background-color:#ffffff4d;color:#fff;border:0px}.range-slider input[type=range]::-moz-range-track{background-color:#fff}.neuroglancer-render-scale-widget{margin-top:2px;margin-bottom:2px;display:flex;flex-direction:row;align-items:center}.neuroglancer-render-scale-widget-prompt{white-space:nowrap}.neuroglancer-render-scale-widget>canvas{height:36px;flex:1;flex-basis:0px;width:0px}.neuroglancer-render-scale-widget-legend{width:15ch;font-size:11px;text-align:right}.neuroglancer-render-scale-widget-legend>div{height:12px}.neuroglancer-segmentation-color-seed-control{display:flex;flex-direction:row;align-items:center;justify-content:flex-end}.neuroglancer-segmentation-color-seed-control input{background-color:#ffffff4d;color:#fff;border:0px}.neuroglancer-selection-details-body{height:0px;flex:1;overflow-y:auto;flex-basis:0px;min-height:0px}.neuroglancer-selection-details-position{display:flex;flex-direction:row;align-items:center;justify-items:left;font-family:monospace;font-size:medium}.neuroglancer-selection-details-position-dimension+.neuroglancer-selection-details-position-dimension{margin-left:8px}.neuroglancer-selection-details-position-dimension-name{color:#ff6}.neuroglancer-selection-details-position-dimension-coordinate{margin-left:5px;user-select:text}.neuroglancer-selection-details-layer{margin-top:4px;margin-bottom:4px;border:1px solid #222}.neuroglancer-selection-details-layer-title{cursor:pointer;background-color:#222;font-family:sans-serif;font-size:10pt}.neuroglancer-selection-details-layer-title:hover{background-color:#333}.neuroglancer-selection-details-layer-body{padding:2px;display:flex;flex-direction:column}.neuroglancer-side-panel-column{display:flex;flex-direction:column;min-width:0px}.neuroglancer-side-panel-row{display:flex;flex-direction:row;min-height:0px}.neuroglancer-side-panel{display:flex;flex-direction:column;min-width:0px;overflow:hidden}.neuroglancer-side-panel-titlebar{display:flex;flex-direction:row;align-items:center;font-family:sans-serif;font-size:10pt;background-color:#03c;padding:2px;color:#fff}.neuroglancer-side-panel-title{flex:1;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.neuroglancer-side-panel-drop-zone{z-index:1000;display:none}[data-neuroglancer-side-panel-drag] .neuroglancer-side-panel-drop-zone{display:block}.neuroglancer-resize-gutter-vertical{height:1px;background-color:#333;background-clip:content-box;padding-top:2px;padding-bottom:2px;cursor:row-resize}.neuroglancer-resize-gutter-horizontal{width:1px;background-color:#333;background-clip:content-box;padding-right:2px;padding-left:2px;cursor:col-resize}.neuroglancer-drag-status{position:absolute;top:0;z-index:1000;background-color:#ff0;color:#000;font:10pt sans-serif;padding:2px}.neuroglancer-eye-icon.neuroglancer-visible>svg>:last-child{display:none}.neuroglancer-eye-icon.neuroglancer-indeterminate>svg>:last-child{stroke:#fff6}/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */.neuroglancer-star-icon>svg{stroke:#fff}.neuroglancer-star-icon.neuroglancer-starred>svg{fill:#fff}.neuroglancer-star-icon.neuroglancer-indeterminate>svg{fill:#fff6}.neuroglancer-annotations-tab,.neuroglancer-annotation-layer-view,.neuroglancer-tags-tab{display:flex;align-items:stretch;flex:1;flex-direction:column}.neuroglancer-annotation-list{position:relative;margin:2px 0 0;padding:0;overflow-y:auto;height:0px;flex:1;flex-basis:0px;min-height:0px}.neuroglancer-annotation-list-entry{display:grid;grid-auto-rows:min-content;cursor:pointer;justify-content:start}.neuroglancer-annotation-position{display:contents}.neuroglancer-annotation-list-header{grid-auto-rows:min-content;display:grid;padding-bottom:2px;justify-content:start}.neuroglancer-annotation-coordinate{font-family:monospace;text-align:right}.neuroglancer-annotation-icon{grid-column:symbol;padding-right:5px}.neuroglancer-annotation-description,.neuroglancer-annotation-tags{grid-column:dim / -1;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.neuroglancer-annotation-list-entry-delete{grid-column:delete;margin-left:1ch;align-self:start;visibility:hidden}.neuroglancer-annotation-list-entry:hover>.neuroglancer-annotation-list-entry-delete{visibility:visible}.neuroglancer-annotation-hover{background-color:#333}.neuroglancer-annotation-selected{background-color:#939}.neuroglancer-annotation-hover.neuroglancer-annotation-selected{background-color:#969}.neuroglancer-tab-content.neuroglancer-annotation-details{flex:0 0 auto;align-self:stretch;display:flex;flex-direction:column;-webkit-touch-callout:default;-webkit-user-select:text;-khtml-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.neuroglancer-annotation-details-title{display:flex;flex-direction:row;background-color:#03c;align-self:stretch;padding:2px}.neuroglancer-voxel-coordinates-link{cursor:pointer}.neuroglancer-voxel-coordinates-link:hover{background-color:#db4437}.neuroglancer-annotation-details-icon{display:inline-block;margin-right:5px}.neuroglancer-annotation-details-title-text{display:inline-block;flex:1}textarea.neuroglancer-annotation-details-description{align-self:stretch;background-color:#222;color:#fff;font:10pt sans-serif;border:0px;outline:0px;resize:none;overflow-y:scroll}div.neuroglancer-annotation-details-description{align-self:stretch;color:#fff;font:10pt sans-serif}.neuroglancer-annotation-toolbox{display:flex;align-items:stretch}.neuroglancer-annotation-segment-item{color:#000;background-color:#fff}.neuroglancer-annotations-view-dimension{font-family:monospace;text-align:right}.neuroglancer-annotations-view-dimension-name{color:#ff6}.neuroglancer-annotations-view-dimension-scale{color:#bbb}.neuroglancer-annotations-view-dimension-scale:not(:empty):before{content:"(";margin-left:1ch}.neuroglancer-annotations-view-dimension-scale:not(:empty):after{content:")"}.neuroglancer-annotation-relationship-label,.neuroglancer-annotation-property-label{margin-right:5px}.neuroglancer-selected-annotation-details-position-grid{display:grid;grid-auto-rows:auto;font-family:monospace;font-size:medium;grid-auto-flow:dense}.neuroglancer-selected-annotation-details-icon{grid-rows:1 / -1;grid-column:icon;align-self:start}.neuroglancer-selected-annotation-details-delete{grid-rows:1 / -1;grid-column:delete;align-self:start}.neuroglancer-selected-annotation-details-position-dim{color:#ff6;margin-left:1ch}.neuroglancer-selected-annotation-details-position-coord{text-align:right;margin-left:.5ch}.neuroglancer-related-segment-list-title{font-family:sans-serif;font-size:small;background-color:#333}.neuroglancer-related-segment-list-header{display:flex;flex-direction:row}.neuroglancer-annotation-property{display:flex;flex-direction:row;font-family:sans-serif;font-size:small;user-select:text}.neuroglancer-annotation-property-label{color:#999}.neuroglancer-annotation-property-value{text-align:right;font-family:monospace;font-size:medium;flex:1}input.neuroglancer-segment-list-entry-id{outline:0px;border:0px;text-align:left}.neuroglancer-segment-list-entry-new>.neuroglancer-segment-list-entry-copy{visibility:hidden}.neuroglancer-segment-list-entry-new>input[type=checkbox]{visibility:hidden}.neuroglancer-selection-annotation-status{font-family:sans-serif;font-size:small}:root{--neuroglancer-segment-list-width: auto}.neuroglancer-segment-list{position:relative;overflow-y:auto;overflow-x:auto;flex:1}.neuroglancer-segment-display-tab{display:flex;flex-direction:column}.neuroglancer-segment-query-errors{margin:0;list-style-type:none;padding:0 0 0 3px;background-color:#333}.neuroglancer-segment-query-errors>li{display:block;color:red}.neuroglancer-segment-list-entry:not(.neuroglancer-segment-list-entry-double-line) .neuroglancer-segment-list-entry-unmapped-id:empty+.neuroglancer-segment-list-entry-copy{display:none}.neuroglancer-segment-list-entry.neuroglancer-segment-list-entry-double-line .neuroglancer-segment-list-entry-unmapped-id:empty+.neuroglancer-segment-list-entry-copy{visibility:hidden}.neuroglancer-segment-list-entry-name:empty+.neuroglancer-segment-list-entry-filter{display:none}.neuroglancer-segment-list-entry-name{order:1000;display:inline-block;font-family:monospace;font-size:medium;user-select:text;white-space:nowrap}.neuroglancer-segment-list-query{background-color:#151515;color:#fff;font-family:monospace;font-size:medium;border:2px solid #333;padding:2px;outline:0px}.neuroglancer-segment-list-query::placeholder{color:#aaa}.neuroglancer-segment-list-status{display:flex;flex-direction:row;align-items:center;background-color:#333}.neuroglancer-segment-list-entry-copy{order:-2;visibility:hidden}.neuroglancer-segment-list-entry:hover .neuroglancer-segment-list-entry-copy{visibility:visible}.neuroglancer-segment-list .neuroglancer-segment-list-entry:not(:hover) .neuroglancer-star-icon:not(.neuroglancer-starred){visibility:hidden}.neuroglancer-segment-list .neuroglancer-segment-list-entry:not(:hover) .neuroglancer-eye-icon:not(.neuroglancer-visible){visibility:hidden}.neuroglancer-segment-list-entry-visible-checkbox{order:1}.neuroglancer-segment-list-entry-filter{visibility:hidden;grid-column:filter;order:999}.neuroglancer-segment-list-entry:hover .neuroglancer-segment-list-entry-filter{visibility:visible}.neuroglancer-segment-query-result-tag-list{display:grid;grid-auto-rows:auto;grid-template-columns:[include] min-content [exclude] min-content [tag] 1fr [count] min-content}.neuroglancer-segment-query-result-tag{display:contents}.neuroglancer-segment-query-result-tag:hover *{background-color:#222}.neuroglancer-segment-query-result-tag-name{grid-column:tag;white-space:nowrap;cursor:pointer;font-weight:700}.neuroglancer-segment-query-result-tag-name:before{content:"#";color:#aaa;font-weight:400}.neuroglancer-segment-query-result-tag-toggle{display:inline-block;white-space:nowrap}.neuroglancer-segment-query-result-tag-include{grid-column:include}.neuroglancer-segment-query-result-tag-exclude{grid-column:exclude}.neuroglancer-segment-query-result-statistics{background-color:#333;max-height:30%;flex-shrink:0;overflow:auto}.neuroglancer-segment-query-result-statistics:not(:empty){padding-top:3px}.neuroglancer-segment-query-result-statistics:not(:empty)+.neuroglancer-segment-list-status{border-top:1px solid white}.neuroglancer-segment-query-result-statistics-separator{height:3px;background-color:#333;border-bottom:1px solid white}.neuroglancer-segment-query-result-tag-count{grid-column:count;text-align:right}.neuroglancer-segment-query-result-tag-count:not(:empty):before{content:"(";color:#aaa}.neuroglancer-segment-query-result-tag-count:not(:empty):after{content:")";color:#aaa}.neuroglancer-segment-query-result-numerical-list{display:flex;flex-direction:column}.neuroglancer-segment-query-result-numerical-plot-container{justify-self:stretch;display:flex;flex-direction:column;padding:2px}.neuroglancer-segment-query-result-numerical-plot{display:block;height:30px;cursor:ew-resize;justify-self:stretch;border:1px solid #666}.neuroglancer-segment-query-result-numerical-plot-bound{background-color:transparent;border-color:transparent;box-shadow:none;border:0;margin:0;font:10pt sans-serif;pointer-events:auto}.neuroglancer-segment-query-result-numerical-plot-window-bound{color:#0ff}.neuroglancer-segment-query-result-numerical-plot-range-bound{color:#fff}.neuroglancer-segment-query-result-numerical-plot-bounds{display:flex;flex-direction:row;color:#aaa}.neuroglancer-segment-query-result-numerical-plot-bound-constraint-symbol{align-self:center}.neuroglancer-segment-query-result-numerical-plot-bound-constraint-spacer{flex:1;color:#fff;font-weight:700;display:flex;flex-direction:row;justify-content:center;align-items:center}.neuroglancer-segment-query-result-numerical-plot-label{cursor:pointer}.neuroglancer-segment-query-result-numerical-plot-sort,.neuroglancer-segment-list-header-label-sort{visibility:hidden}.neuroglancer-segment-query-result-numerical-plot-label:hover .neuroglancer-segment-query-result-numerical-plot-sort,.neuroglancer-segment-list-header-label:hover .neuroglancer-segment-list-header-label-sort,.neuroglancer-segment-query-result-numerical-plot-container:hover .neuroglancer-segment-query-result-numerical-plot-bounds-window{visibility:visible}.neuroglancer-segment-query-result-numerical-plot-bounds-window{justify-content:space-between;margin-top:-16px;visibility:hidden;pointer-events:none}.neuroglancer-segment-list-entry.neuroglancer-segment-list-header{background-color:#666}.neuroglancer-segment-list-header .neuroglancer-segment-list-entry-id{background-color:inherit;color:#fff;text-align:center}.neuroglancer-segment-list-header-label{cursor:pointer;font:10pt sans-serif}.neuroglancer-segment-list-header .neuroglancer-segment-list-entry-extra-property{text-align:center}.neuroglancer-segment-list-status-message{overflow:hidden;white-space:nowrap}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */.neuroglancer-merge-segments-status{display:flex;flex-direction:row}.neuroglancer-merge-segments-status .neuroglancer-segment-list-entry{margin-left:1em;margin-right:1em}.overlay{height:100%;width:100%;position:fixed;z-index:99;top:0;left:0;background-color:#000c}.overlay-content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fff;z-index:100;color:#000;padding:1em}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */.neuroglancer-linked-layer-widget-layer{display:flex;flex-direction:row}.neuroglancer-linked-layer-widget-layer:hover{background-color:#333}.neuroglancer-shader-code-widget.invalid-input{border:1px solid red}.neuroglancer-shader-code-widget.valid-input{border:1px solid green}.neuroglancer-shader-code-widget{border:1px solid transparent}.CodeMirror{font-family:monospace;height:300px;color:#000;direction:ltr}.CodeMirror-lines{padding:4px 0}.CodeMirror pre.CodeMirror-line,.CodeMirror pre.CodeMirror-line-like{padding:0 4px}.CodeMirror-scrollbar-filler,.CodeMirror-gutter-filler{background-color:#fff}.CodeMirror-gutters{border-right:1px solid #ddd;background-color:#f7f7f7;white-space:nowrap}.CodeMirror-linenumber{padding:0 3px 0 5px;min-width:20px;text-align:right;color:#999;white-space:nowrap}.CodeMirror-guttermarker{color:#000}.CodeMirror-guttermarker-subtle{color:#999}.CodeMirror-cursor{border-left:1px solid black;border-right:none;width:0}.CodeMirror div.CodeMirror-secondarycursor{border-left:1px solid silver}.cm-fat-cursor .CodeMirror-cursor{width:auto;border:0!important;background:#7e7}.cm-fat-cursor div.CodeMirror-cursors{z-index:1}.cm-fat-cursor .CodeMirror-line::selection,.cm-fat-cursor .CodeMirror-line>span::selection,.cm-fat-cursor .CodeMirror-line>span>span::selection{background:transparent}.cm-fat-cursor .CodeMirror-line::-moz-selection,.cm-fat-cursor .CodeMirror-line>span::-moz-selection,.cm-fat-cursor .CodeMirror-line>span>span::-moz-selection{background:transparent}.cm-fat-cursor{caret-color:transparent}@-moz-keyframes blink{50%{background-color:transparent}}@-webkit-keyframes blink{50%{background-color:transparent}}@keyframes blink{50%{background-color:transparent}}.cm-tab{display:inline-block;text-decoration:inherit}.CodeMirror-rulers{position:absolute;inset:-50px 0 0;overflow:hidden}.CodeMirror-ruler{border-left:1px solid #ccc;top:0;bottom:0;position:absolute}.cm-s-default .cm-header{color:#00f}.cm-s-default .cm-quote{color:#090}.cm-negative{color:#d44}.cm-positive{color:#292}.cm-header,.cm-strong{font-weight:700}.cm-em{font-style:italic}.cm-link{text-decoration:underline}.cm-strikethrough{text-decoration:line-through}.cm-s-default .cm-keyword{color:#708}.cm-s-default .cm-atom{color:#219}.cm-s-default .cm-number{color:#164}.cm-s-default .cm-def{color:#00f}.cm-s-default .cm-variable-2{color:#05a}.cm-s-default .cm-variable-3,.cm-s-default .cm-type{color:#085}.cm-s-default .cm-comment{color:#a50}.cm-s-default .cm-string{color:#a11}.cm-s-default .cm-string-2{color:#f50}.cm-s-default .cm-meta,.cm-s-default .cm-qualifier{color:#555}.cm-s-default .cm-builtin{color:#30a}.cm-s-default .cm-bracket{color:#997}.cm-s-default .cm-tag{color:#170}.cm-s-default .cm-attribute{color:#00c}.cm-s-default .cm-hr{color:#999}.cm-s-default .cm-link{color:#00c}.cm-s-default .cm-error,.cm-invalidchar{color:red}.CodeMirror-composing{border-bottom:2px solid}div.CodeMirror span.CodeMirror-matchingbracket{color:#0b0}div.CodeMirror span.CodeMirror-nonmatchingbracket{color:#a22}.CodeMirror-matchingtag{background:#ff96004d}.CodeMirror-activeline-background{background:#e8f2ff}.CodeMirror{position:relative;overflow:hidden;background:#fff}.CodeMirror-scroll{overflow:scroll!important;margin-bottom:-50px;margin-right:-50px;padding-bottom:50px;height:100%;outline:none;position:relative;z-index:0}.CodeMirror-sizer{position:relative;border-right:50px solid transparent}.CodeMirror-vscrollbar,.CodeMirror-hscrollbar,.CodeMirror-scrollbar-filler,.CodeMirror-gutter-filler{position:absolute;z-index:6;display:none;outline:none}.CodeMirror-vscrollbar{right:0;top:0;overflow-x:hidden;overflow-y:scroll}.CodeMirror-hscrollbar{bottom:0;left:0;overflow-y:hidden;overflow-x:scroll}.CodeMirror-scrollbar-filler{right:0;bottom:0}.CodeMirror-gutter-filler{left:0;bottom:0}.CodeMirror-gutters{position:absolute;left:0;top:0;min-height:100%;z-index:3}.CodeMirror-gutter{white-space:normal;height:100%;display:inline-block;vertical-align:top;margin-bottom:-50px}.CodeMirror-gutter-wrapper{position:absolute;z-index:4;background:none!important;border:none!important}.CodeMirror-gutter-background{position:absolute;top:0;bottom:0;z-index:4}.CodeMirror-gutter-elt{position:absolute;cursor:default;z-index:4}.CodeMirror-gutter-wrapper ::selection{background-color:transparent}.CodeMirror-gutter-wrapper ::-moz-selection{background-color:transparent}.CodeMirror-lines{cursor:text;min-height:1px}.CodeMirror pre.CodeMirror-line,.CodeMirror pre.CodeMirror-line-like{-moz-border-radius:0;-webkit-border-radius:0;border-radius:0;border-width:0;background:transparent;font-family:inherit;font-size:inherit;margin:0;white-space:pre;word-wrap:normal;line-height:inherit;color:inherit;z-index:2;position:relative;overflow:visible;-webkit-tap-highlight-color:transparent;-webkit-font-variant-ligatures:contextual;font-variant-ligatures:contextual}.CodeMirror-wrap pre.CodeMirror-line,.CodeMirror-wrap pre.CodeMirror-line-like{word-wrap:break-word;white-space:pre-wrap;word-break:normal}.CodeMirror-linebackground{position:absolute;inset:0;z-index:0}.CodeMirror-linewidget{position:relative;z-index:2;padding:.1px}.CodeMirror-rtl pre{direction:rtl}.CodeMirror-code{outline:none}.CodeMirror-scroll,.CodeMirror-sizer,.CodeMirror-gutter,.CodeMirror-gutters,.CodeMirror-linenumber{-moz-box-sizing:content-box;box-sizing:content-box}.CodeMirror-measure{position:absolute;width:100%;height:0;overflow:hidden;visibility:hidden}.CodeMirror-cursor{position:absolute;pointer-events:none}.CodeMirror-measure pre{position:static}div.CodeMirror-cursors{visibility:hidden;position:relative;z-index:3}div.CodeMirror-dragcursors,.CodeMirror-focused div.CodeMirror-cursors{visibility:visible}.CodeMirror-selected{background:#d9d9d9}.CodeMirror-focused .CodeMirror-selected{background:#d7d4f0}.CodeMirror-crosshair{cursor:crosshair}.CodeMirror-line::selection,.CodeMirror-line>span::selection,.CodeMirror-line>span>span::selection{background:#d7d4f0}.CodeMirror-line::-moz-selection,.CodeMirror-line>span::-moz-selection,.CodeMirror-line>span>span::-moz-selection{background:#d7d4f0}.cm-searching{background-color:#ffa;background-color:#ff06}.cm-force-border{padding-right:.1px}@media print{.CodeMirror div.CodeMirror-cursors{visibility:hidden}}.cm-tab-wrap-hack:after{content:""}span.CodeMirror-selectedtext{background:none}.CodeMirror-lint-markers{width:16px}.CodeMirror-lint-tooltip{background-color:#ffd;border:1px solid black;border-radius:4px;color:#000;font-family:monospace;font-size:10pt;overflow:hidden;padding:2px 5px;position:fixed;white-space:pre;white-space:pre-wrap;z-index:100;max-width:600px;opacity:0;transition:opacity .4s;-moz-transition:opacity .4s;-webkit-transition:opacity .4s;-o-transition:opacity .4s;-ms-transition:opacity .4s}.CodeMirror-lint-mark{background-position:left bottom;background-repeat:repeat-x}.CodeMirror-lint-mark-warning{background-image:url()}.CodeMirror-lint-mark-error{background-image:url()}.CodeMirror-lint-marker{background-position:center center;background-repeat:no-repeat;cursor:pointer;display:inline-block;height:16px;width:16px;vertical-align:middle;position:relative}.CodeMirror-lint-message{padding-left:18px;background-position:top left;background-repeat:no-repeat}.CodeMirror-lint-marker-warning,.CodeMirror-lint-message-warning{background-image:url()}.CodeMirror-lint-marker-error,.CodeMirror-lint-message-error{background-image:url()}.CodeMirror-lint-marker-multiple{background-image:url();background-repeat:no-repeat;background-position:right bottom;width:100%;height:100%}.CodeMirror-lint-line-error{background-color:#b74c5114}.CodeMirror-lint-line-warning{background-color:#ffd3001a}.neuroglancer-layer-data-sources-tab{display:flex;flex-direction:column}.neuroglancer-layer-data-sources-container{overflow-y:auto;display:flex;flex-direction:column;flex:1;height:0px;z-index:1}.neuroglancer-layer-data-source-url-input input.autocomplete-input{color:#fff}.neuroglancer-layer-data-source-url-input input.autocomplete-hint{color:#aaa}.neuroglancer-layer-data-source-url-input .autocomplete-dropdown{background-color:#333}.neuroglancer-layer-data-sources-source-id{font-weight:700}.neuroglancer-layer-data-sources-source-id:not(:empty):before{content:"["}.neuroglancer-layer-data-sources-source-id:not(:empty):after{content:"]"}.neuroglancer-layer-data-sources-source-id:not(:empty){margin-right:4px;color:#0ff}.neuroglancer-layer-data-sources-source-messages:empty{display:none}.neuroglancer-layer-data-sources-source-messages{margin-top:0;list-style:none;padding-left:0}li.neuroglancer-message{word-wrap:break-word;user-select:text}li.neuroglancer-message-error{color:red}li.neuroglancer-message-warning{color:#ff0}li.neuroglancer-message-info{color:#ccc}.neuroglancer-layer-data-sources-source-default{display:block;margin-bottom:4px}.neuroglancer-layer-data-sources-info-line[data-is-active=false]{text-decoration:solid line-through #caa}.neuroglancer-layer-data-sources-tab-type-detection{position:sticky;bottom:0;background-color:#ff9;color:#000;text-align:center;cursor:pointer}.neuroglancer-layer-data-sources-tab-type-detection:hover{background-color:#ffc}.neuroglancer-layer-data-sources-tab-type-detection-type{font-weight:700}.neuroglancer-coordinate-space-transform-widget{display:grid;justify-items:stretch}.neuroglancer-coordinate-space-transform-widget input{font-family:monospace;justify-self:stretch;background-color:#000;color:#fff;padding:2px}.neuroglancer-coordinate-space-transform-widget *[data-will-be-deleted=true]{color:#666}.neuroglancer-coordinate-space-transform-label{font-style:italic;color:#fcc;align-self:center}.neuroglancer-coordinate-space-transform-input-lower-label{grid-row:sourceLower;grid-column:outputLabel / sourceDim 1}.neuroglancer-coordinate-space-transform-translation-label{grid-row:sourceLabel / outputDim 1;grid-column:sourceDim -1;writing-mode:vertical-lr;text-orientation:mixed;align-self:end;justify-self:center;margin-bottom:2px}.neuroglancer-coordinate-space-transform-input-lower-label,.neuroglancer-coordinate-space-transform-input-upper-label,.neuroglancer-coordinate-space-transform-input-scale-label{text-align:right;margin-right:4px}.neuroglancer-coordinate-space-transform-input-upper-label{grid-row:sourceUpper;grid-column:headerStart / headerEnd}.neuroglancer-coordinate-space-transform-input-scale-label{grid-row:5;grid-column:headerStart / headerEnd}.neuroglancer-coordinate-space-transform-source-label{grid-row:sourceLabel;grid-column:sourceDim 1 / sourceDim -1;text-align:center}.neuroglancer-coordinate-space-transform-output-label{grid-row:outputDim 1 / outputDim -1;grid-column:outputLabel;writing-mode:vertical-lr;text-orientation:mixed;align-self:center;justify-self:end;margin-right:2px}.neuroglancer-coordinate-space-transform-input-name{text-align:center}.neuroglancer-coordinate-space-transform-input-name,input.neuroglancer-coordinate-space-transform-output-name{font-family:monospace;color:#ff6}.neuroglancer-coordinate-space-transform-scale{text-align:right}.neuroglancer-coordinate-space-transform-input-bounds,.neuroglancer-coordinate-space-transform-output-bounds{white-space:nowrap;font-family:monospace;font-size:small;text-align:right;padding-left:2px;padding-right:2px;color:#aff}.neuroglancer-coordinate-space-transform-input-bounds.neuroglancer-coordinate-space-transform-singleton:not(*[data-will-be-deleted=true]){color:#fa6}.neuroglancer-coordinate-space-transform-widget input[data-is-valid=false],.neuroglancer-coordinate-space-transform-widget input[data-is-valid=false]::placeholder{text-decoration:solid underline red}.neuroglancer-coordinate-space-transform-output-extend{grid-row:outputDim -1;grid-column:outputNames;display:flex;flex-direction:column}.neuroglancer-coordinate-space-transform-output-extend input{align-self:stretch}.neuroglancer-coordinate-space-transform-output-extend[data-is-active=false] input,.neuroglancer-coordinate-space-transform-output-extend[data-is-active=true] .neuroglancer-icon{display:none}.neuroglancer-coordinate-space-transform-output-extend .neuroglancer-icon{align-self:start}.neuroglancer-coordinate-space-transform-translation-coeff{margin-left:3px}.neuroglancer-coordinate-space-transform-output-scale-container{margin-right:3px}.neuroglancer-coordinate-space-transform-input-scale-container,.neuroglancer-coordinate-space-transform-input-scale-label{margin-bottom:3px}.neuroglancer-coordinate-space-transform-widget input,.neuroglancer-coordinate-space-transform-output-name-container,.neuroglancer-coordinate-space-transform-scale-container{border:1px solid #333}.neuroglancer-coordinate-space-transform-widget .neuroglancer-coordinate-space-transform-output-name,.neuroglancer-coordinate-space-transform-widget .neuroglancer-coordinate-space-transform-scale{border:0px}.neuroglancer-coordinate-space-transform-output-name-container{display:flex;flex-direction:column;align-items:stretch;margin-right:3px}.neuroglancer-coordinate-space-transform-scale-container{display:flex;flex-direction:column;align-items:stretch}.neuroglancer-coordinate-space-transform-scale-suggestion{font-family:monospace;cursor:pointer;border-radius:20%;border:1px solid #333;align-self:flex-end;margin:2px;color:#aaa}.neuroglancer-coordinate-space-transform-scale-suggestion svg{width:16px;height:16px;fill:transparent;stroke:#aaa;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.neuroglancer-coordinate-space-transform-scale-suggestion:hover{background-color:#db4437;border:1px solid transparent;color:#fff}.neuroglancer-coordinate-space-transform-scale-suggestion:hover svg{stroke:#fff}.neuroglancer-coordinate-space-transform-widget-reset-buttons{grid-row:outputDim -1;grid-column:headerEnd / -1;justify-self:start}.neuroglancer-multiline-autocomplete{margin-top:2px;padding:2px;position:relative;background-color:#222}.neuroglancer-multiline-autocomplete-hint,.neuroglancer-multiline-autocomplete-input{font-family:monospace;color:#fff;word-wrap:break-word}.neuroglancer-multiline-autocomplete-input:focus{outline:0px}.neuroglancer-multiline-autocomplete-input:not(:focus):empty:before{content:attr(data-placeholder);color:#aaa}.neuroglancer-multiline-autocomplete-hint{color:#aaa}.neuroglancer-multiline-autocomplete-hint,.neuroglancer-multiline-autocomplete-input,.neuroglancer-multiline-autocomplete-completion{font-family:monospace;font-size:medium}.neuroglancer-multiline-autocomplete-dropdown{color:#fff;background-color:#181818;position:fixed;display:block;outline:0;margin:0;padding:0;left:0;right:0;text-align:left;cursor:default;border-style:solid;border-width:1px;border-color:#aaa;overflow-y:scroll;word-wrap:break-word}.neuroglancer-multiline-autocomplete-completion:nth-child(2n):not(.neuroglancer-multiline-autocomplete-completion-active){background-color:#2b2b2b}.neuroglancer-multiline-autocomplete-completion:hover{outline:1px solid #ddd}.neuroglancer-multiline-autocomplete-completion-active{background-color:#666}.neuroglancer-multiline-autocomplete-completion-description{font-style:italic;color:#f9f}.neuroglancer-image-dropdown{overflow-y:auto;display:flex;flex-direction:column;height:0px}.neuroglancer-image-dropdown .neuroglancer-shader-code-widget{flex-shrink:0;height:8em;border:1px solid transparent}.neuroglancer-image-dropdown-top-row{display:flex;flex-direction:row;align-items:center}.neuroglancer-image-layer-shader-overlay .neuroglancer-shader-code-widget{width:80vw;height:80vh}.neuroglancer-selection-details-value-grid{display:grid;grid-auto-rows:auto;font-family:monospace;font-size:medium;align-items:center}.neuroglancer-selection-details-value-grid-dim{grid-column:dim;color:#ff6}.neuroglancer-selection-details-value-grid-dim:after{content:"=";color:#aaa}.neuroglancer-selection-details-value-grid-coord{grid-column:coord;color:#aaa;margin-right:1ch}.neuroglancer-selection-details-value-grid-value{grid-column:value;user-select:text}.neuroglancer-channel-dimensions-widget-dim{display:contents}.neuroglancer-channel-dimensions-widget{display:grid;grid-template-columns:[name] min-content [lower] min-content [upper] min-content}.neuroglancer-channel-dimensions-widget-name-container{grid-column:name}.neuroglancer-channel-dimensions-widget-name[data-is-valid=false],.neuroglancer-channel-dimensions-widget-name::placeholder{text-decoration:solid underline red}.neuroglancer-channel-dimensions-widget-name{background-color:transparent;border-color:transparent;box-shadow:none;border:0;margin:0;font-family:monospace;font-size:medium;color:#ff6}.neuroglancer-channel-dimensions-widget-name,.neuroglancer-channel-dimensions-widget-lower,.neuroglancer-channel-dimensions-widget-upper{font-family:monospace}.neuroglancer-channel-dimensions-widget-lower{grid-column:lower;text-align:right}.neuroglancer-channel-dimensions-widget-upper{grid-column:upper;text-align:right}.neuroglancer-channel-dimensions-widget-lower,.neuroglancer-channel-dimensions-widget-upper{text-align:right;margin-left:1ch;user-select:text}.neuroglancer-channel-dimensions-widget-upper:after{content:")"}.neuroglancer-channel-dimensions-widget-lower:after{content:","}.neuroglancer-channel-dimensions-widget-lower:before{content:"["}.neuroglancer-channel-dimensions-widget-upper:after,.neuroglancer-channel-dimensions-widget-lower:before,.neuroglancer-channel-dimensions-widget-lower:after{color:#999}.neuroglancer-single-mesh-dropdown .neuroglancer-single-mesh-attribute-widget{max-height:6em;margin-bottom:8px}.neuroglancer-single-mesh-dropdown .neuroglancer-shader-code-widget{height:6em;width:60ch;border:1px solid transparent}.neuroglancer-single-mesh-dropdown-top-row{display:flex;flex-direction:row;align-items:center}.neuroglancer-single-mesh-shader-overlay .neuroglancer-shader-code-widget{width:80vw;height:80vh}.neuroglancer-single-mesh-attribute-widget{word-wrap:break-word;overflow-y:auto;display:grid;grid-template-columns:[type] auto [name] auto [range] auto}.neuroglancer-single-mesh-layer-shader-overlay .neuroglancer-single-mesh-attribute-widget{max-height:20vh}.neuroglancer-single-mesh-attribute{font-family:monospace;display:contents}.neuroglancer-single-mesh-attribute-type{color:#c6c;grid-column:type}.neuroglancer-single-mesh-attribute-name{margin-left:1ch;color:#fff;grid-column:name;user-select:text}.neuroglancer-single-mesh-attribute-range{margin-left:1ch;white-space:nowrap;color:#999;grid-column:range}.neuroglancer-graphene-tab .neuroglancer-annotation-toolbox{display:none}.neuroglancer-graphene-tab div[data-color="#ff0000"]>.neuroglancer-annotation-position{color:red}.neuroglancer-graphene-tab div[data-color="#0000ff"]>.neuroglancer-annotation-position{color:#44f}.graphene-tool-status{display:flex;gap:10px}.graphene-multicut>.activeGroupIndicator{padding:2px;margin:auto 0;background-color:red;font:12px sans-serif;font-weight:900}.graphene-multicut>.activeGroupIndicator.blueGroup{background-color:#00f}.graphene-multicut>.activeGroupIndicator:after{content:"Red"}.graphene-multicut>.activeGroupIndicator.blueGroup:after{content:"Blue"}.graphene-merge-segments-merges{display:flex;flex-direction:column}.graphene-merge-segments-submission{display:flex;gap:10px}.graphene-tool-status .neuroglancer-icon{height:100%}.graphene-merge-segments-status label{display:grid;grid-template-columns:min-content min-content;white-space:nowrap;justify-content:center;align-content:center}.graphene-merge-segments-point{display:flex;align-items:center;gap:10px}.graphene-merge-segments-point .neuroglancer-segment-list-entry-visible-checkbox,.graphene-merge-segments-point .neuroglancer-segment-list-entry-copy-container{display:none}.graphene-find-path>label{display:flex}.graphene-find-path>label>span{display:flex;align-content:center;flex-wrap:wrap}.find-path-annotations{display:flex;gap:10px}.find-path-annotations>.neuroglancer-annotation-list-entry{background-color:#000}html,body{margin:0;padding:0;overflow:hidden;width:100vw;height:100vh;background-color:#000;color:#fff}body{position:relative;display:flex;flex-direction:column}#neuroglancer-container{width:100vw;overflow:hidden;flex:1}.neuroglancer-viewer{outline:0px}.neuroglancer-viewer-top-row{display:flex;flex-direction:row;align-items:center;background-color:#222;margin-bottom:3px;padding-right:2px}.neuroglancer-viewer-side-panel{display:flex;flex-direction:column;align-items:stretch;max-width:80%;color:#fff}.neuroglancer-noselect{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.neuroglancer-select-text{-webkit-touch-callout:default;-webkit-user-select:text;-khtml-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.neuroglancer-data-panel-layout-controls{position:absolute;top:2px;right:2px;display:flex;align-items:start}.neuroglancer-data-panel-layout-controls>button{display:flex;margin:2px;border:0px;background-color:#00000080;flex-direction:row;align-self:top;align-items:center;justify-content:center;border:1px solid white;font-size:15px;width:18px;height:18px;color:#fff}.neuroglancer-data-panel-layout-controls>button>div{display:inline-block;text-align:center;line-height:12px;width:15px;height:15px}.neuroglancer-data-panel-layout-controls>button:hover{color:#6ff}label.perspective-panel-show-slice-views{pointer-events:none;position:absolute;right:2px;bottom:2px;font-family:sans-serif;font-size:small}input.perspective-panel-show-slice-views{pointer-events:all}.neuroglancer-rendered-data-panel{cursor:crosshair;position:relative;outline:0;touch-action:none;color:#fff;text-align:left}.neuroglancer-display-dimensions-widget{position:absolute;cursor:default;top:2px;left:2px;background-color:#0000004d}.neuroglancer-display-dimensions-widget-dimension-grid{display:grid;grid-template-rows:0fr 0fr 0fr 0fr;grid-template-columns:0fr 0fr 0fr}.neuroglancer-display-dimensions-widget input{outline:0px;background-color:transparent;border-color:transparent;box-shadow:none;margin:0;border:0;padding:2px}.neuroglancer-display-dimensions-widget input,.neuroglancer-display-dimensions-widget{font-family:monospace;color:#fff}.neuroglancer-display-dimensions-widget-dimension:hover{outline:1px solid black}.neuroglancer-display-dimensions-widget-name[data-is-valid=false]{text-decoration:solid underline red}.neuroglancer-display-dimensions-widget-scale-factor{text-align:right;align-items:end;display:inline-block;white-space:nowrap;margin-left:2px}.neuroglancer-display-dimensions-widget-scale{display:inline-block;white-space:nowrap;padding-left:10px}.neuroglancer-display-dimensions-widget-scale:not(:empty):before{content:"("}.neuroglancer-display-dimensions-widget-scale:not(:empty):after{content:")"}.neuroglancer-display-dimensions-widget-scale-factor:after{content:"\d7"}.neuroglancer-display-dimensions-widget-scale{text-align:right;margin-left:5px}.neuroglancer-display-dimensions-widget:not(:hover):not([data-active=true]) .neuroglancer-display-dimensions-widget-scale-factor,.neuroglancer-display-dimensions-widget:not(:hover):not([data-active=true]) .neuroglancer-display-dimensions-widget-scale,.neuroglancer-display-dimensions-widget:not(:hover):not([data-active=true]) .neuroglancer-display-dimensions-widget-default,.neuroglancer-display-dimensions-widget:not(:hover):not([data-active=true]) .neuroglancer-depth-range-widget-grid,.neuroglancer-display-dimensions-widget:not(:hover):not([data-active=true]) .neuroglancer-depth-range-relative-checkbox-label{display:none}.neuroglancer-display-dimensions-widget-dimension[data-is-modified=true] .neuroglancer-display-dimensions-widget-scale-factor,.neuroglancer-display-dimensions-widget-dimension[data-is-modified=true] .neuroglancer-display-dimensions-widget-scale{visibility:hidden}.neuroglancer-display-dimensions-widget *:focus{outline:0px}.neuroglancer-display-dimensions-widget-default{grid-row:4;grid-column-start:1;grid-column-end:3;display:inline-block;white-space:nowrap}.neuroglancer-display-dimensions-widget-default input{margin-right:3px}.neuroglancer-depth-range-widget-grid{margin-top:1em;display:grid;grid-template-columns:0fr 0fr 0fr;grid-auto-rows:0fr}.neuroglancer-depth-range-widget-dimension-names:not(:empty):before{content:"("}.neuroglancer-depth-range-widget-dimension-names:not(:empty):after{content:")"}.neuroglancer-depth-range-widget-dimension-names{margin-left:1ch;white-space:nowrap}.neuroglancer-help-body{flex-basis:0px;flex:1;height:0px;min-height:0px;font-family:sans-serif;display:flex;flex-direction:column}.neuroglancer-help-scroll-container{flex:1;flex-basis:0px;position:relative;overflow:auto}.neuroglancer-help-scroll-container div+h2{margin-top:1em}.neuroglancer-help-scroll-container h2{font-size:10pt;padding:4px;position:sticky;top:0;background-color:#333;margin-top:0}.neuroglancer-help-scroll-container .dt{font-family:monospace;font-weight:700;color:#ff0}.neuroglancer-help-scroll-container .dd{font-size:10pt;margin-left:4ex}.neuroglancer-build-info{font-size:10pt;user-select:text}.neuroglancer-build-info a{color:#fff;text-decoration:none;font-weight:700}.neuroglancer-build-info a:hover{background-color:#db4437}.neuroglancer-panel{flex:1}.neuroglancer-show-panel-borders .neuroglancer-panel{border-style:solid;border-color:#000;border-width:2px}.neuroglancer-panel:focus-within{border-color:#fff}.neuroglancer-layer-group-viewer{outline:0px}.neuroglancer-layer-group-viewer-context-menu{flex-direction:column;align-items:stretch}.neuroglancer-layer-group-viewer-context-menu label{display:flex;flex-direction:row;justify-content:space-between}.neuroglancer-layer-group-viewer-context-menu select:before{flex:1;content:" "}.neuroglancer-layer-group-viewer-context-menu select{margin-left:5px}.neuroglancer-context-menu{position:absolute;z-index:100;border:1px solid white;background-color:#000;box-shadow:5px 5px 2px 1px #00000080;font-family:sans-serif;font-size:11pt;padding:5px;color:#fff;outline:0px}:root{--layer-number-color: #9a7518}.neuroglancer-layer-panel{width:100%;display:flex;flex-direction:row;flex-wrap:wrap;align-items:stretch;margin-left:-5px;margin-top:-1px;z-index:-.1}.neuroglancer-layer-item{position:relative;display:flex;align-items:center;color:#fff;cursor:pointer;border-width:1px;border-style:solid;border-color:#ccc;font-family:sans-serif;font-size:10pt;background-color:#000;padding:1px}.neuroglancer-layer-item,.neuroglancer-layer-add-button{margin:1px 1px 1px 5px}.neuroglancer-layer-item[data-selected=true]{border-color:#8c8}.neuroglancer-layer-item[data-selected=true]:hover{border-color:#3c3}.neuroglancer-layer-item:hover{border-color:#daa520}.neuroglancer-layer-item[data-pick=true] .neuroglancer-layer-item-label{background-color:#939}.neuroglancer-layer-item-label{display:inline-block;position:relative;background-color:#222;padding-right:3px}.neuroglancer-layer-item-number{display:inline-block;background-color:var(--layer-number-color);font-weight:700;padding-left:1px;padding-right:1px}.neuroglancer-layer-panel[data-show-hover-values=true] .neuroglancer-layer-item-value{display:inline-block;font-family:monospace;font-size:medium;max-width:50ch;margin-left:1ch;white-space:nowrap;overflow:hidden;text-overflow:ellipses;text-align:center}.neuroglancer-layer-panel[data-show-hover-values=false] .neuroglancer-layer-item-value{display:none}.neuroglancer-layer-item[data-visible=false] .neuroglancer-layer-item-label{text-decoration:line-through}.neuroglancer-layer-item[data-visible=false]{color:#bbb}.neuroglancer-layer-panel-drop-zone{display:inline-block;flex:1}.neuroglancer-layer-item-visible-progress,.neuroglancer-layer-item-prefetch-progress{position:absolute;left:0;height:2px;background-color:#666}.neuroglancer-layer-item-visible-progress{top:0}.neuroglancer-layer-item-prefetch-progress{bottom:0}.neuroglancer-layer-item-value-container{display:grid;grid-template-columns:min-content;align-items:center}.neuroglancer-layer-item-value{grid-row:1;grid-column:1;visibility:visible}.neuroglancer-layer-item-button-container{grid-row:1;grid-column:1;white-space:nowrap;display:flex;flex-direction:row;align-items:center;visibility:hidden;justify-self:right}.neuroglancer-layer-panel:hover .neuroglancer-layer-item-value{visibility:hidden}.neuroglancer-layer-panel:hover .neuroglancer-layer-item-button-container{visibility:visible}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */.neuroglancer-layout-split-drop-zone{position:absolute;z-index:1000}.neuroglancer-drag-over{background-color:#0000ff80}.neuroglancer-stack-layout-row>.neuroglancer-stack-layout-drop-placeholder{padding-left:4px;padding-right:4px;width:1px;cursor:col-resize}.neuroglancer-stack-layout-column>.neuroglancer-stack-layout-drop-placeholder{padding-top:4px;padding-bottom:4px;height:1px;cursor:row-resize}.neuroglancer-stack-layout-drop-placeholder{background-clip:content-box;background-color:#666;z-index:1}.neuroglancer-stack-layout-drop-placeholder.neuroglancer-drag-over{background-clip:border-box;background-color:#8080ff80}.neuroglancer-stack-layout-drop-placeholder:first-child,.neuroglancer-stack-layout-drop-placeholder:last-child{display:none}.neuroglancer-layer-list-panel-items{display:flex;flex-direction:column;flex:1;overflow:auto;height:0px;min-height:0px;flex-basis:0px}.neuroglancer-layer-list-panel-item{display:flex;flex-direction:row;padding:2px;border:1px solid #aaa;margin:2px}.neuroglancer-layer-list-panel-item[data-selected=true]{border-color:#3c3}.neuroglancer-layer-list-panel-item[data-archived=true]{border-color:#666}.neuroglancer-layer-list-panel-item[data-archived=true] .neuroglancer-layer-side-panel-name,.neuroglancer-layer-list-panel-item[data-archived=true] .neuroglancer-icon svg{color:#999;stroke:#999}.neuroglancer-layer-list-panel-item:hover{background-color:#333}.neuroglancer-layer-list-panel-item-number{font-family:sans-serif;background-color:var(--layer-number-color);color:#fff;font-weight:700;display:inline-block}.neuroglancer-layer-list-panel-item:not(:hover)>.neuroglancer-layer-list-panel-item-delete{display:none}.neuroglancer-layer-list-panel-item:not(:hover)>.neuroglancer-layer-list-panel-item-controls{display:none}[data-neuroglancer-layer-panel-pinned=false] .neuroglancer-side-panel-titlebar.neuroglancer-layer-side-panel-title{background-color:#393}[data-neuroglancer-layer-visible=false] .neuroglancer-side-panel-titlebar.neuroglancer-layer-side-panel-title input{text-decoration:line-through}.neuroglancer-layer-side-panel-name{flex:1;background-color:transparent;border:0px;color:#fff;outline:0px;width:0px;min-width:0px}.neuroglancer-layer-side-panel-tab-view{flex:1;display:flex;flex-direction:column;font:10pt sans-serif}.neuroglancer-layer-side-panel-type-measure{position:absolute;visibility:hidden;top:0;height:auto;width:auto;white-space:nowrap}.neuroglancer-layer-side-panel-type,.neuroglancer-layer-side-panel-type-measure{padding-left:3px;padding-right:3px;font-weight:700;font-family:sans-serif;font-size:10pt;box-sizing:border-box}.neuroglancer-layer-side-panel-type{-webkit-appearance:none;color:#fff;cursor:pointer;background-color:#00000080;margin-right:5px;border:0px;outline:0px}.neuroglancer-layer-side-panel-type option{background-color:#000}.CodeMirror-foldmarker{color:#00f;text-shadow:#b9f 1px 1px 2px,#b9f -1px -1px 2px,#b9f 1px -1px 2px,#b9f -1px 1px 2px;font-family:arial;line-height:.3;cursor:pointer}.CodeMirror-foldgutter{width:.7em}.CodeMirror-foldgutter-open,.CodeMirror-foldgutter-folded{cursor:pointer}.CodeMirror-foldgutter-open:after{content:"\25be"}.CodeMirror-foldgutter-folded:after{content:"\25b8"}.neuroglancer-state-editor{width:80%}.close-button{position:absolute;right:15px}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */.neuroglancer-statistics-panel-body{flex:1;flex-basis:0px;min-width:0px;display:flex;flex-direction:column;overflow-y:auto;font:10pt sans-serif}.neuroglancer-statistics-panel-body>table{position:relative;flex:1;width:100%}.neuroglancer-statistics-panel-body>table>thead td{position:sticky;top:0;z-index:2;background-color:#333;font-weight:700}.neuroglancer-statistics-panel-body>table>tbody tr:hover{background-color:#336}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */.neuroglancer-settings-body{flex-basis:0px;flex:1;height:0px;min-height:0px;font-family:sans-serif;display:flex;flex-direction:column;font-size:10pt}.neuroglancer-settings-body input[type=text],.neuroglancer-settings-body input[type=number]{background-color:#333;color:#fff;border:0px}.neuroglancer-settings-scroll-container{flex:1;flex-basis:0px;position:relative;overflow:auto;display:flex;flex-direction:column}.neuroglancer-settings-scroll-container>*{margin-top:3px}.neuroglancer-settings-title{align-self:stretch}.neuroglancer-settings-scroll-container>label{display:flex;flex-direction:row;justify-content:space-between}.neuroglancer-settings-scroll-container>label>input:before{flex:1;content:" "}.neuroglancer-settings-scroll-container>label>input{margin-left:5px;width:11ch}.neuroglancer-settings-limit-widget>input{width:11ch}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */.neuroglancer-annotation-tool-status{display:flex;flex-direction:row;align-items:center;overflow-x:scroll;scrollbar-width:none}.neuroglancer-annotation-tool-status::-webkit-scrollbar{display:none}.neuroglancer-annotation-tool-status-widget+.neuroglancer-annotation-tool-status-widget{margin-left:3px}.neuroglancer-annotation-tool-status-widget:hover{outline:1px solid #fff}.neuroglancer-annotation-tool-status-widget{display:flex;flex-direction:row;align-items:center}.neuroglancer-annotation-tool-status-widget-layer-number{display:inline-block;font:10pt sans-serif;font-weight:700;background-color:#9a7518}.neuroglancer-annotation-tool-status-widget-key{display:inline-block;font:9pt monospace;color:#0ff}.neuroglancer-annotation-tool-status-widget-key:before{content:"["}.neuroglancer-annotation-tool-status-widget-key:after{content:"]"}.neuroglancer-annotation-tool-status-widget-key:before,.neuroglancer-annotation-tool-status-widget-key:after{color:#999}.neuroglancer-annotation-tool-status-widget-description{display:inline-block;color:#3c3;font:10pt sans-serif;white-space:nowrap}.neuroglancer-annotation-tool-status-widget-delete{visibility:hidden}.neuroglancer-annotation-tool-status-widget:hover>.neuroglancer-annotation-tool-status-widget-delete{visibility:inherit} + +/*# sourceMappingURL=main.cb26101b553ed6b82856.css.map*/ \ No newline at end of file diff --git a/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.css.map b/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.css.map new file mode 100644 index 0000000..66436e3 --- /dev/null +++ b/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.css.map @@ -0,0 +1 @@ +{"version":3,"file":"main.cb26101b553ed6b82856.css","mappings":"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","sources":["webpack://neuroglancer/./src/layer/annotation/style.css","webpack://neuroglancer/./src/widget/transfer_function.css","webpack://neuroglancer/./src/widget/invlerp.css","webpack://neuroglancer/./src/widget/icon.css","webpack://neuroglancer/./src/widget/tab_view.css","webpack://neuroglancer/./src/widget/position_widget.css","webpack://neuroglancer/./src/status.css","webpack://neuroglancer/./src/ui/tool.css","webpack://neuroglancer/./src/widget/checkbox_icon.css","webpack://neuroglancer/./src/widget/position_plot.css","webpack://neuroglancer/./src/layer/segmentation/style.css","webpack://neuroglancer/./src/widget/layer_control.css","webpack://neuroglancer/./src/widget/range.css","webpack://neuroglancer/./src/widget/render_scale_widget.css","webpack://neuroglancer/./src/widget/segmentation_color_mode.css","webpack://neuroglancer/./src/ui/selection_details.css","webpack://neuroglancer/./src/ui/side_panel.css","webpack://neuroglancer/./src/ui/drag_and_drop.css","webpack://neuroglancer/./src/widget/eye_button.css","webpack://neuroglancer/./src/widget/star_button.css","webpack://neuroglancer/./src/ui/annotations.css","webpack://neuroglancer/./src/ui/segment_list.css","webpack://neuroglancer/./src/ui/segment_split_merge_tools.css","webpack://neuroglancer/./src/overlay.css","webpack://neuroglancer/./src/widget/linked_layer.css","webpack://neuroglancer/./src/widget/shader_code_widget.css","webpack://neuroglancer/./node_modules/codemirror/lib/codemirror.css","webpack://neuroglancer/./node_modules/codemirror/addon/lint/lint.css","webpack://neuroglancer/./src/ui/layer_data_sources_tab.css","webpack://neuroglancer/./src/widget/coordinate_transform.css","webpack://neuroglancer/./src/widget/multiline_autocomplete.css","webpack://neuroglancer/./src/layer/image/style.css","webpack://neuroglancer/./src/widget/channel_dimensions_widget.css","webpack://neuroglancer/./src/layer/single_mesh/style.css","webpack://neuroglancer/./src/datasource/graphene/graphene.css","webpack://neuroglancer/./src/ui/default_viewer.css","webpack://neuroglancer/./src/viewer.css","webpack://neuroglancer/./src/noselect.css","webpack://neuroglancer/./src/data_panel_layout.css","webpack://neuroglancer/./src/perspective_view/panel.css","webpack://neuroglancer/./src/rendered_data_panel.css","webpack://neuroglancer/./src/widget/display_dimensions_widget.css","webpack://neuroglancer/./src/help/input_event_bindings.css","webpack://neuroglancer/./src/layer_group_viewer.css","webpack://neuroglancer/./src/ui/context_menu.css","webpack://neuroglancer/./src/ui/layer_bar.css","webpack://neuroglancer/./src/layer_groups_layout.css","webpack://neuroglancer/./src/ui/layer_list_panel.css","webpack://neuroglancer/./src/ui/layer_side_panel.css","webpack://neuroglancer/./node_modules/codemirror/addon/fold/foldgutter.css","webpack://neuroglancer/./src/ui/state_editor.css","webpack://neuroglancer/./src/ui/statistics.css","webpack://neuroglancer/./src/ui/viewer_settings.css","webpack://neuroglancer/./src/widget/annotation_tool_status.css"],"sourcesContent":["/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-annotation-rendering-tab {\n display: flex;\n flex-direction: column;\n overflow-y: auto;\n}\n\n.neuroglancer-annotation-rendering-tab .neuroglancer-shader-code-widget {\n flex-shrink: 0;\n}\n\n.neuroglancer-annotation-shader-property-list {\n max-height: 8em;\n overflow: auto;\n flex-shrink: 0;\n}\n\n.neuroglancer-annotation-shader-property {\n white-space: pre;\n font-family: monospace;\n font-size: medium;\n}\n\n.neuroglancer-annotation-shader-property-type {\n color: #c6c;\n margin-right: 1ch;\n}\n\n.neuroglancer-annotation-shader-property-identifier {\n user-select: text;\n}\n\n.neuroglancer-annotation-shader-property-identifier::after {\n content: \"()\";\n color: #999;\n}\n\n.neuroglancer-annotation-tag-property-type {\n color: #999;\n}\n\n.neuroglancer-tag-list > div {\n display: grid;\n}\n\n.neuroglancer-add-tag-control > input,\n.neuroglancer-tag-list-entry > input {\n background-color: #151515;\n color: white;\n font-family: monospace;\n font-size: medium;\n border: 2px solid #333;\n padding: 2px;\n outline: 0px;\n}\n\n/* copy of .neuroglancer-annotation-layer-view */\n/* layer/annotation/style.css vs src/ui/annotations.css */\n.neuroglancer-tags-container {\n display: flex;\n flex-direction: column;\n flex: 1;\n align-items: stretch;\n}\n\n.neuroglancer-tag-list-outer {\n position: relative;\n margin: 0px;\n padding: 0px;\n margin-top: 2px;\n overflow-y: auto;\n height: 0px;\n flex: 1;\n flex-basis: 0px;\n min-height: 0px;\n}\n\n.neuroglancer-tag-list-entry {\n display: grid;\n grid-template-columns: min-content auto min-content;\n align-items: center;\n white-space: nowrap;\n padding: 2px 20px 2px 0;\n}\n\n.neuroglancer-tag-list-entry.add .neuroglancer-tool-button {\n visibility: hidden;\n}\n\n.neuroglancer-tag-list-entry:hover .neuroglancer-tag-list-entry-delete {\n visibility: visible;\n}\n\n.neuroglancer-tag-list-entry .neuroglancer-tag-list-entry-delete {\n visibility: hidden;\n}","/**\n * @license\n * Copyright 2024 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-transfer-function-panel {\n height: 60px;\n border: 1px solid #666;\n margin-top: 5px;\n}\n\n.neuroglancer-transfer-function-color-picker {\n text-align: right;\n}\n\n.neuroglancer-transfer-function-widget-bound {\n background-color: transparent;\n border-color: transparent;\n box-shadow: none;\n border: 0;\n margin: 0;\n font-family: monospace;\n font-size: medium;\n color: cyan;\n}\n\n.neuroglancer-transfer-function-window-bounds {\n display: flex;\n justify-content: space-between;\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-invlerp-cdfpanel {\n height: 50px;\n cursor: ew-resize;\n}\n\n.neuroglancer-invlerp-cdfpanel,\n.neuroglancer-invlerp-legend-panel {\n border: 1px solid #666;\n}\n\n.neuroglancer-invlerp-legend-panel {\n height: 15px;\n}\n\n.neuroglancer-invlerp-widget-bound {\n background-color: transparent;\n border-color: transparent;\n box-shadow: none;\n border: 0;\n margin: 0;\n font-family: monospace;\n font-size: medium;\n}\n\n.neuroglancer-invlerp-widget-window-bound {\n color: cyan;\n}\n\n.neuroglancer-invlerp-widget-range-bound {\n color: white;\n}\n\n.neuroglancer-invlerp-widget-bounds {\n display: flex;\n}\n\n.neuroglancer-invlerp-widget-range-spacer {\n flex: 1;\n text-align: center;\n}\n\n.neuroglancer-invlerp-widget-window-bounds {\n justify-content: space-between;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n.neuroglancer-icon {\n display: inline-flex;\n text-decoration: none;\n align-self: center;\n white-space: nowrap;\n padding-left: 2px;\n padding-right: 2px;\n min-width: 18px;\n min-height: 18px;\n border-radius: 20%;\n align-items: center;\n justify-content: center;\n color: white;\n font: 12px sans-serif;\n cursor: pointer;\n font-weight: 900;\n margin-left: 1px;\n margin-right: 1px;\n user-select: none;\n}\n\n.neuroglancer-icon svg {\n width: 16px;\n height: 16px;\n fill: transparent;\n stroke: white;\n stroke-width: 2;\n stroke-linecap: round;\n stroke-linejoin: round;\n}\n\n.neuroglancer-icon:hover {\n background-color: #db4437;\n}\n\n.neuroglancer-icon-hover:not(:hover) svg:last-child {\n display: none;\n}\n\n.neuroglancer-icon-hover:hover svg:first-child {\n display: none;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-tab-view {\n display: flex;\n flex-direction: column;\n}\n\n.neuroglancer-tab-view-bar {\n display: block;\n background-color: #333;\n border-bottom: 1px solid white;\n}\n\n.neuroglancer-tab-label {\n display: inline-block;\n border-top: 1px solid transparent;\n border-left: 1px solid transparent;\n border-right: 1px solid transparent;\n border-bottom: none;\n margin-right: 4px;\n padding-top: 1px;\n padding-left: 2px;\n padding-right: 2px;\n font: 10pt sans-serif;\n font-weight: bold;\n cursor: pointer;\n}\n.neuroglancer-tab-label:hover {\n color: #daa520;\n}\n\n.neuroglancer-tab-label.neuroglancer-selected-tab-label {\n background-color: black;\n border-top: 1px solid white;\n border-left: 1px solid white;\n border-right: 1px solid white;\n border-bottom: 1px solid black;\n padding-bottom: 1px;\n margin-bottom: -1px;\n}\n\n.neuroglancer-stack-view {\n display: contents;\n}\n\n.neuroglancer-tab-view > .neuroglancer-stack-view > .neuroglancer-tab-content {\n flex: 1;\n flex-basis: 0px;\n height: 0px;\n min-height: 0px;\n padding: 2px;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-position-widget {\n display: inline-flex;\n align-items: center;\n}\n\n/* In Firefox, disabled input elements block all pointer events, even on parent elements, and that\ninterferes with our click handling. Setting `pointer-events: none;` avoids that problem. */\n.neuroglancer-position-widget input:disabled {\n pointer-events: none;\n}\n\n.neuroglancer-position-widget .neuroglancer-copy-button:first-child {\n display: none;\n}\n\n.neuroglancer-position-dimension-coordinate,\n.neuroglancer-position-dimension-name,\n.neuroglancer-position-dimension-scale {\n background-color: transparent;\n border-color: transparent;\n box-shadow: none;\n border: 0;\n margin: 0;\n font-family: monospace;\n font-size: medium;\n}\n\n.neuroglancer-position-dimension[data-coordinate-array=\"valid\"]\n .neuroglancer-position-dimension-scale {\n display: none;\n}\n\n.neuroglancer-position-dimension[data-coordinate-array=\"invalid\"]\n .neuroglancer-position-dimension-scale {\n text-decoration-line: underline;\n text-decoration-style: wavy;\n text-decoration-color: red;\n}\n\n.neuroglancer-position-dimension-coordinate {\n color: white;\n text-align: right;\n}\n\n.neuroglancer-position-widget input:invalid,\n.neuroglancer-position-widget input::placeholder,\n.neuroglancer-position-widget input[data-is-valid=\"false\"] {\n text-decoration: solid underline red;\n}\n\n.neuroglancer-position-widget *:focus {\n outline: 0px;\n}\n\n.neuroglancer-position-dimension + .neuroglancer-position-dimension {\n margin-left: 1ch;\n}\n\n.neuroglancer-position-dimension[data-dropdown-visible=\"true\"]::after {\n content: \"\";\n display: block;\n left: 0px;\n right: 0px;\n bottom: -1px;\n position: absolute;\n border-bottom: 1px solid black;\n z-index: 100;\n height: 0px;\n}\n\n.neuroglancer-position-dimension-dropdown,\n.neuroglancer-position-dimension-coordinate-dropdown {\n position: absolute;\n min-width: calc(100% + 2px);\n border: 1px solid #aaa;\n box-sizing: border-box;\n padding: 2px;\n left: -1px;\n z-index: 100;\n background-color: black;\n}\n\n.neuroglancer-position-dimension-coordinate-dropdown {\n display: flex;\n flex-direction: column;\n overflow-y: auto;\n}\n\n.neuroglancer-dimension-dropdown-coordinate-entry {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n}\n\n.neuroglancer-dimension-dropdown-coordinate-entry:hover {\n background-color: #333;\n}\n\n.neuroglancer-dimension-dropdown-coordinate-label {\n width: var(--neuroglancer-coordinate-label-width);\n color: #0ff;\n}\n\n.neuroglancer-position-dimension-dropdown:focus,\n.neuroglancer-position-dimension-coordinate-dropdown:focus {\n outline: 0px;\n}\n\n.neuroglancer-position-dimension:focus-within,\n.neuroglancer-position-dimension[data-dropdown-visible=\"true\"] {\n border: 1px solid #aaa;\n background-color: black;\n}\n\n.neuroglancer-position-dimension {\n border: 1px solid transparent;\n position: relative;\n display: inline-block;\n white-space: nowrap;\n}\n\n.neuroglancer-position-dimension-name {\n color: #ff6;\n padding-left: 2px;\n}\n\n.neuroglancer-position-dimension-scale-container[data-is-empty=\"false\"]::before {\n content: \"(\";\n color: #aaa;\n}\n\n.neuroglancer-position-dimension-scale-container[data-is-empty=\"false\"]::after {\n content: \")\";\n color: #aaa;\n}\n\n.neuroglancer-position-dimension-scale-container[data-is-empty=\"false\"] {\n margin-right: 5px;\n}\n\n.neuroglancer-position-dimension-scale {\n color: #bbb;\n}\n\n.neuroglancer-position-dimension-scale-container {\n margin-right: 2px;\n margin-left: 4px;\n}\n\n.neuroglancer-mouse-position-widget {\n margin-left: 1ch;\n vertical-align: center;\n font-family: monospace;\n font-size: medium;\n color: orange;\n white-space: pre;\n}\n\n.neuroglancer-position-dimension-coordinate-label {\n display: inline-block;\n color: #0ff;\n}\n\n.neuroglancer-position-dimension-coordinate-label:not(:empty)::before {\n content: \"[\";\n color: #aaa;\n}\n\n.neuroglancer-position-dimension-coordinate-label:not(:empty)::after {\n content: \"]\";\n color: #aaa;\n}\n\n.neuroglancer-position-dimension-playback {\n font-family: sans-serif;\n font-size: 10pt;\n display: flex;\n flex-direction: column;\n}\n\n.neuroglancer-position-dimension-playback .neuroglancer-number-input {\n display: flex;\n flex-direction: row;\n align-items: center;\n margin-bottom: 2px;\n}\n\n.neuroglancer-position-dimension-playback input[type=\"text\"] {\n background-color: rgba(255, 255, 255, 0.3);\n color: #fff;\n border: 0px;\n font-family: monospace;\n width: 8ch;\n text-align: right;\n}\n\n.neuroglancer-position-dimension-playback select {\n align-self: center;\n}\n\n.neuroglancer-position-dimension > .neuroglancer-icon {\n min-width: 14px;\n min-height: 14px;\n position: relative;\n top: 1px;\n}\n\n.neuroglancer-position-dimension > .neuroglancer-icon svg {\n width: 12px;\n height: 12px;\n}\n\n.neuroglancer-position-tool {\n background-color: #474747;\n}\n\n.neuroglancer-position-dimension-playback-header {\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n#statusContainer {\n position: absolute;\n bottom: 0px;\n z-index: 100;\n background-color: #808080;\n color: white;\n margin: 0px;\n padding: 0px;\n font: 10pt sans-serif;\n}\n\n#statusContainer li {\n width: 100vw;\n max-height: 25vh;\n overflow-y: auto;\n}\n\n.neuroglancer-status-header {\n display: inline-block;\n font: 10pt sans-serif;\n font-weight: bold;\n background-color: #333;\n padding: 2px;\n}\n\n#statusContainerModal {\n pointer-events: none;\n position: absolute;\n z-index: 100;\n color: white;\n margin: 0px;\n padding: 0px;\n font: 10pt sans-serif;\n\n display: grid;\n align-content: center;\n justify-content: center;\n height: 100vh;\n width: 80vw;\n left: 10vw;\n grid-row-gap: 10px;\n}\n\n#statusContainerModal > div {\n pointer-events: initial;\n position: relative;\n background-color: #808080;\n padding: 20px;\n padding-top: 30px;\n}\n\n#statusContainerModal > div > div:first-child {\n position: absolute;\n top: 4px;\n right: 4px;\n margin: 0;\n padding: 0;\n}\n\n#statusContainerModal li {\n display: block;\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-tool-key-binding {\n display: inline-block;\n color: #0ff;\n font: 9pt monospace;\n white-space: pre;\n}\n\n.neuroglancer-tool-key-binding:hover {\n outline: 1px solid #fff;\n}\n\n.neuroglancer-tool-key-binding::before {\n content: \"[\";\n}\n\n.neuroglancer-tool-key-binding::after {\n content: \"]\";\n}\n\n.neuroglancer-tool-key-binding::before,\n.neuroglancer-tool-key-binding::after {\n color: #999;\n}\n\n.neuroglancer-tool-button {\n display: inline-flex;\n flex-direction: row;\n}\n\n#statusContainer li.neuroglancer-tool-status {\n max-height: 50vh;\n}\n\n.neuroglancer-tool-status-bindings {\n background-color: #333;\n user-select: none;\n}\n\n.neuroglancer-tool-status-content {\n display: flex;\n flex-direction: row;\n}\n\n.neuroglancer-tool-status-header-container {\n background-color: #555;\n width: min-content;\n padding: 3px;\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.neuroglancer-tool-status-header {\n align-self: center;\n}\n\n.neuroglancer-tool-status-body {\n flex: 1;\n padding: 2px;\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-checkbox-icon.light-background[data-checked=\"true\"] {\n background-color: rgba(0, 0, 0, 0.5);\n}\n\n.neuroglancer-checkbox-icon.dark-background[data-checked=\"true\"] {\n background-color: rgba(255, 255, 255, 0.2);\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-position-dimension-plot {\n display: grid;\n overflow: hidden;\n position: relative;\n}\n\n.neuroglancer-position-dimension-plot[data-orientation=\"column\"] {\n grid-template-areas: \"labels . graph\";\n grid-template-rows: 1fr;\n grid-template-columns: 0fr 3px 0fr;\n}\n\n.neuroglancer-position-dimension-plot[data-orientation=\"row\"] {\n grid-template-areas:\n \"labels\"\n \".\"\n \"graph\";\n grid-template-columns: minmax(0px, 1fr);\n grid-template-rows: 0fr 3px 0fr;\n}\n\n.neuroglancer-position-dimension-plot-lowerbound,\n.neuroglancer-position-dimension-plot-upperbound,\n.neuroglancer-position-dimension-plot-hoverposition {\n grid-area: labels;\n font-family: monospace;\n font-size: medium;\n user-select: none;\n}\n\n.neuroglancer-position-dimension-plot[data-orientation=\"column\"]\n :is(\n .neuroglancer-position-dimension-plot-lowerbound,\n .neuroglancer-position-dimension-plot-upperbound,\n .neuroglancer-position-dimension-plot-hoverposition\n ) {\n text-align: right;\n}\n\n.neuroglancer-position-dimension-plot[data-orientation=\"row\"]\n :is(\n .neuroglancer-position-dimension-plot-lowerbound,\n .neuroglancer-position-dimension-plot-upperbound,\n .neuroglancer-position-dimension-plot-hoverposition\n ) {\n max-width: max-content;\n}\n\n.neuroglancer-position-dimension-plot > canvas {\n grid-area: graph;\n}\n\n.neuroglancer-position-dimension-plot[data-orientation=\"column\"] > canvas {\n margin-top: 0.5em;\n margin-bottom: 0.5em;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-segmentation-rendering-tab {\n display: flex;\n flex-direction: column;\n overflow-y: auto;\n}\n\n.neuroglancer-segmentation-rendering-tab .neuroglancer-shader-code-widget {\n height: 6em;\n}\n\n.neuroglancer-segmentation-dropdown-skeleton-shader-header {\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.neuroglancer-segmentation-layer-skeleton-shader-overlay\n .neuroglancer-shader-code-widget {\n width: 80vw;\n height: 80vh;\n}\n\n.neuroglancer-segment-list-entry {\n display: flex;\n flex-direction: row;\n width: min-content;\n min-width: 100%;\n background-color: black;\n align-items: start;\n}\n\n.neuroglancer-segment-list-entry.neuroglancer-segment-list-entry-double-line {\n display: inline-flex;\n min-width: initial;\n background-color: initial;\n}\n\n.neuroglancer-segment-list-entry[data-selected=\"true\"],\n.neuroglancer-selection-details-segment[data-selected=\"true\"] {\n background-color: #222;\n}\n\n.neuroglancer-segment-list-entry-copy-container {\n display: flex;\n flex-direction: column;\n}\n\n.neuroglancer-segment-list-entry-id-container {\n order: 1;\n align-self: center;\n}\n\n.neuroglancer-segment-list-entry-id,\n.neuroglancer-selection-details-segment-id {\n display: block;\n font-family: monospace;\n font-size: medium;\n flex-shrink: 0;\n text-align: right;\n color: black;\n background-color: white;\n user-select: text;\n width: var(--neuroglancer-segment-list-width);\n}\n\n.neuroglancer-segment-list .neuroglancer-segment-list-entry-sticky {\n position: sticky;\n left: 0;\n}\n\n.neuroglancer-segment-list-entry-sticky {\n white-space: nowrap;\n flex-direction: row;\n align-items: start;\n background-color: inherit;\n display: flex;\n}\n\n.neuroglancer-segment-list-entry.neuroglancer-segment-list-header\n .neuroglancer-segment-list-entry-star,\n.neuroglancer-segment-list-entry.neuroglancer-segment-list-header:hover\n .neuroglancer-segment-list-entry-copy {\n visibility: hidden;\n}\n\n.neuroglancer-segment-list-entry-extra-property {\n padding-left: 8px;\n flex-shrink: 0;\n text-align: right;\n user-select: text;\n}\n\n.neuroglancer-selection-details-segment-description,\n.neuroglancer-selection-details-segment-property {\n font-family: sans-serif;\n font-size: small;\n}\n\n.neuroglancer-selection-details-segment-property {\n display: flex;\n flex-direction: row;\n}\n\n.neuroglancer-selection-details-segment-property-name {\n user-select: text;\n font-style: italic;\n}\n\n.neuroglancer-selection-details-segment-property-value {\n text-align: right;\n flex: 1;\n}\n\n.neuroglancer-segmentation-toolbox {\n display: inline-block;\n}\n\n.neuroglancer-segmentation-toolbox\n .neuroglancer-tool-button\n + .neuroglancer-tool-button {\n margin-left: 1em;\n}\n\n.neuroglancer-segment-list-entry .neuroglancer-color-widget {\n border: none;\n border-color: transparent;\n appearance: none;\n background-color: transparent;\n padding: 0;\n margin: 0;\n margin-left: 3px;\n height: 19px;\n width: 20px;\n}\n\n.neuroglancer-segment-list-entry .neuroglancer-color-widget.overridden {\n background-color: white;\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-layer-options-control-container\n .neuroglancer-layer-control-label-container {\n margin-right: auto;\n}\n\n.neuroglancer-layer-control-label-container {\n white-space: nowrap;\n}\n\n.neuroglancer-layer-control-label {\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.neuroglancer-layer-control-label-text-container {\n display: flex;\n flex-direction: row;\n align-items: start;\n}\n\n.neuroglancer-layer-control-container {\n margin-top: 1.5px;\n margin-bottom: 1.5px;\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.neuroglancer-layer-control-control {\n flex: 1;\n margin-left: 5px;\n max-width: 500px;\n}\n\nselect.neuroglancer-layer-control-control,\ninput[type=\"checkbox\"].neuroglancer-layer-control-control,\ninput[type=\"color\"].neuroglancer-layer-control-control {\n flex: initial;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.range-slider {\n display: flex;\n flex-direction: row;\n white-space: nowrap;\n justify-content: flex-end;\n}\n\n.range-slider input[type=\"range\"] {\n background: transparent;\n flex-basis: 0px;\n}\n\n.range-slider input[type=\"number\"] {\n background-color: rgba(255, 255, 255, 0.3);\n color: #fff;\n border: 0px;\n}\n\n.range-slider input[type=\"range\"]::-moz-range-track {\n background-color: white;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-render-scale-widget {\n margin-top: 2px;\n margin-bottom: 2px;\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.neuroglancer-render-scale-widget-prompt {\n white-space: nowrap;\n}\n\n.neuroglancer-render-scale-widget > canvas {\n height: 36px;\n flex: 1;\n flex-basis: 0px;\n width: 0px;\n}\n\n.neuroglancer-render-scale-widget-legend {\n width: 15ch;\n font-size: 11px;\n text-align: right;\n}\n\n.neuroglancer-render-scale-widget-legend > div {\n height: 12px;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-segmentation-color-seed-control {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: flex-end;\n}\n\n.neuroglancer-segmentation-color-seed-control input {\n background-color: rgba(255, 255, 255, 0.3);\n color: #fff;\n border: 0px;\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-selection-details-body {\n height: 0px;\n flex: 1;\n overflow-y: auto;\n flex-basis: 0px;\n min-height: 0px;\n}\n\n.neuroglancer-selection-details-position {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-items: left;\n font-family: monospace;\n font-size: medium;\n}\n\n.neuroglancer-selection-details-position-dimension\n + .neuroglancer-selection-details-position-dimension {\n margin-left: 8px;\n}\n\n.neuroglancer-selection-details-position-dimension-name {\n color: #ff6;\n}\n\n.neuroglancer-selection-details-position-dimension-coordinate {\n margin-left: 5px;\n user-select: text;\n}\n\n.neuroglancer-selection-details-layer {\n margin-top: 4px;\n margin-bottom: 4px;\n border: 1px solid #222;\n}\n\n.neuroglancer-selection-details-layer-title {\n cursor: pointer;\n background-color: #222;\n font-family: sans-serif;\n font-size: 10pt;\n}\n\n.neuroglancer-selection-details-layer-title:hover {\n background-color: #333;\n}\n\n.neuroglancer-selection-details-layer-body {\n padding: 2px;\n display: flex;\n flex-direction: column;\n}\n",".neuroglancer-side-panel-column {\n display: flex;\n flex-direction: column;\n min-width: 0px;\n}\n\n.neuroglancer-side-panel-row {\n display: flex;\n flex-direction: row;\n min-height: 0px;\n}\n\n.neuroglancer-side-panel {\n display: flex;\n flex-direction: column;\n min-width: 0px;\n overflow: hidden;\n}\n\n.neuroglancer-side-panel-titlebar {\n display: flex;\n flex-direction: row;\n align-items: center;\n font-family: sans-serif;\n font-size: 10pt;\n background-color: #03c;\n padding: 2px;\n color: white;\n}\n\n.neuroglancer-side-panel-title {\n flex: 1;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n}\n\n.neuroglancer-side-panel-drop-zone {\n z-index: 1000;\n display: none;\n}\n\n[data-neuroglancer-side-panel-drag] .neuroglancer-side-panel-drop-zone {\n display: block;\n}\n\n.neuroglancer-resize-gutter-vertical {\n height: 1px;\n background-color: #333;\n background-clip: content-box;\n padding-top: 2px;\n padding-bottom: 2px;\n cursor: row-resize;\n}\n\n.neuroglancer-resize-gutter-horizontal {\n width: 1px;\n background-color: #333;\n background-clip: content-box;\n padding-right: 2px;\n padding-left: 2px;\n cursor: col-resize;\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-drag-status {\n position: absolute;\n top: 0px;\n z-index: 1000;\n background-color: yellow;\n color: black;\n font: 10pt sans-serif;\n padding: 2px;\n}\n","/**\n * @license\n * Copyright 2023 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-eye-icon.neuroglancer-visible > svg > :last-child {\n display: none;\n}\n\n.neuroglancer-eye-icon.neuroglancer-indeterminate > svg > :last-child {\n stroke: rgba(255, 255, 255, 0.4);\n}\n","/**\n * @license\n * Copyright 2023 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-star-icon > svg {\n stroke: white;\n}\n\n.neuroglancer-star-icon.neuroglancer-starred > svg {\n fill: white;\n}\n\n.neuroglancer-star-icon.neuroglancer-indeterminate > svg {\n fill: rgba(255, 255, 255, 0.4);\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-annotations-tab, .neuroglancer-annotation-layer-view, .neuroglancer-tags-tab {\n display: flex;\n align-items: stretch;\n flex: 1;\n flex-direction: column;\n}\n\n.neuroglancer-annotation-list {\n position: relative;\n margin: 0px;\n padding: 0px;\n margin-top: 2px;\n overflow-y: auto;\n height: 0px;\n flex: 1;\n flex-basis: 0px;\n min-height: 0px;\n}\n\n.neuroglancer-annotation-list-entry {\n display: grid;\n grid-auto-rows: min-content;\n cursor: pointer;\n justify-content: start;\n}\n\n.neuroglancer-annotation-position {\n display: contents;\n}\n\n.neuroglancer-annotation-list-header {\n grid-auto-rows: min-content;\n display: grid;\n padding-bottom: 2px;\n justify-content: start;\n}\n\n.neuroglancer-annotation-coordinate {\n font-family: monospace;\n text-align: right;\n}\n\n.neuroglancer-annotation-icon {\n grid-column: symbol;\n padding-right: 5px;\n}\n\n.neuroglancer-annotation-description, .neuroglancer-annotation-tags {\n grid-column: dim / -1;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n}\n\n.neuroglancer-annotation-list-entry-delete {\n grid-column: delete;\n margin-left: 1ch;\n align-self: start;\n visibility: hidden;\n}\n\n.neuroglancer-annotation-list-entry:hover\n > .neuroglancer-annotation-list-entry-delete {\n visibility: visible;\n}\n\n.neuroglancer-annotation-hover {\n background-color: #333;\n}\n\n.neuroglancer-annotation-selected {\n background-color: #939;\n}\n\n.neuroglancer-annotation-hover.neuroglancer-annotation-selected {\n background-color: #969;\n}\n\n.neuroglancer-tab-content.neuroglancer-annotation-details {\n flex: 0 0 auto;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -khtml-user-select: text;\n -moz-user-select: text;\n -ms-user-select: text;\n user-select: text;\n}\n\n.neuroglancer-annotation-details-title {\n display: flex;\n flex-direction: row;\n background-color: #03c;\n align-self: stretch;\n padding: 2px;\n}\n\n.neuroglancer-voxel-coordinates-link {\n cursor: pointer;\n}\n\n.neuroglancer-voxel-coordinates-link:hover {\n background-color: #db4437;\n}\n\n.neuroglancer-annotation-details-icon {\n display: inline-block;\n margin-right: 5px;\n}\n\n.neuroglancer-annotation-details-title-text {\n display: inline-block;\n flex: 1;\n}\n\ntextarea.neuroglancer-annotation-details-description {\n align-self: stretch;\n background-color: #222;\n color: white;\n font: 10pt sans-serif;\n border: 0px;\n outline: 0px;\n resize: none;\n overflow-y: scroll;\n}\n\ndiv.neuroglancer-annotation-details-description {\n align-self: stretch;\n color: white;\n font: 10pt sans-serif;\n}\n\n.neuroglancer-annotation-details-position {\n}\n\n.neuroglancer-annotation-toolbox {\n display: flex;\n align-items: stretch;\n}\n\n.neuroglancer-annotation-segment-list {\n}\n\n.neuroglancer-annotation-segment-item {\n color: black;\n background-color: white;\n}\n\n.neuroglancer-annotations-view-dimension {\n font-family: monospace;\n text-align: right;\n}\n\n.neuroglancer-annotations-view-dimension-name {\n color: #ff6;\n}\n\n.neuroglancer-annotations-view-dimension-scale {\n color: #bbb;\n}\n\n.neuroglancer-annotations-view-dimension-scale:not(:empty)::before {\n content: \"(\";\n margin-left: 1ch;\n}\n\n.neuroglancer-annotations-view-dimension-scale:not(:empty)::after {\n content: \")\";\n}\n\n.neuroglancer-annotation-relationship-label,\n.neuroglancer-annotation-property-label {\n margin-right: 5px;\n}\n\n.neuroglancer-selected-annotation-details-position-grid {\n display: grid;\n grid-auto-rows: auto;\n font-family: monospace;\n font-size: medium;\n grid-auto-flow: dense;\n}\n\n.neuroglancer-selected-annotation-details-icon {\n grid-rows: 1 / -1;\n grid-column: icon;\n align-self: start;\n}\n\n.neuroglancer-selected-annotation-details-delete {\n grid-rows: 1 / -1;\n grid-column: delete;\n align-self: start;\n}\n\n.neuroglancer-selected-annotation-details-position-dim {\n color: #ff6;\n margin-left: 1ch;\n}\n\n.neuroglancer-selected-annotation-details-position-coord {\n text-align: right;\n margin-left: 0.5ch;\n}\n\n.neuroglancer-related-segment-list-title {\n font-family: sans-serif;\n font-size: small;\n background-color: #333;\n}\n\n.neuroglancer-related-segment-list-header {\n display: flex;\n flex-direction: row;\n}\n\n.neuroglancer-related-segment-list {\n /* border: 1px solid #333;\n margin: 3px;*/\n}\n\n.neuroglancer-annotation-property {\n display: flex;\n flex-direction: row;\n font-family: sans-serif;\n font-size: small;\n user-select: text;\n}\n\n.neuroglancer-annotation-property-label {\n color: #999;\n}\n\n.neuroglancer-annotation-property-value {\n text-align: right;\n font-family: monospace;\n font-size: medium;\n flex: 1;\n}\n\ninput.neuroglancer-segment-list-entry-id {\n outline: 0px;\n border: 0px;\n text-align: left;\n}\n\n.neuroglancer-segment-list-entry-new > .neuroglancer-segment-list-entry-copy {\n visibility: hidden;\n}\n\n.neuroglancer-segment-list-entry-new > input[type=\"checkbox\"] {\n visibility: hidden;\n}\n\n.neuroglancer-selection-annotation-status {\n font-family: sans-serif;\n font-size: small;\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n:root {\n --neuroglancer-segment-list-width: auto;\n}\n\n.neuroglancer-segment-list {\n position: relative;\n overflow-y: auto;\n overflow-x: auto;\n flex: 1;\n}\n\n.neuroglancer-segment-display-tab {\n display: flex;\n flex-direction: column;\n}\n\n.neuroglancer-segment-query-errors {\n margin: 0px;\n list-style-type: none;\n padding: 0px;\n padding-left: 3px;\n background-color: #333;\n}\n\n.neuroglancer-segment-query-errors > li {\n display: block;\n color: red;\n}\n\n.neuroglancer-segment-list-entry:not(\n .neuroglancer-segment-list-entry-double-line\n )\n .neuroglancer-segment-list-entry-unmapped-id:empty\n + .neuroglancer-segment-list-entry-copy {\n display: none;\n}\n\n.neuroglancer-segment-list-entry.neuroglancer-segment-list-entry-double-line\n .neuroglancer-segment-list-entry-unmapped-id:empty\n + .neuroglancer-segment-list-entry-copy {\n visibility: hidden;\n}\n\n.neuroglancer-segment-list-entry-name:empty\n + .neuroglancer-segment-list-entry-filter {\n display: none;\n}\n\n.neuroglancer-segment-list-entry-name {\n order: 1000;\n display: inline-block;\n font-family: monospace;\n font-size: medium;\n user-select: text;\n white-space: nowrap;\n}\n\n.neuroglancer-segment-list-query {\n background-color: #151515;\n color: white;\n font-family: monospace;\n font-size: medium;\n border: 2px solid #333;\n padding: 2px;\n outline: 0px;\n}\n\n.neuroglancer-segment-list-query::placeholder {\n color: #aaa;\n}\n\n.neuroglancer-segment-list-status {\n display: flex;\n flex-direction: row;\n align-items: center;\n background-color: #333;\n}\n\n.neuroglancer-segment-list-entry-copy {\n order: -2;\n visibility: hidden;\n}\n\n.neuroglancer-segment-list-entry:hover .neuroglancer-segment-list-entry-copy {\n visibility: visible;\n}\n\n.neuroglancer-segment-list\n .neuroglancer-segment-list-entry:not(:hover)\n .neuroglancer-star-icon:not(.neuroglancer-starred) {\n visibility: hidden;\n}\n\n.neuroglancer-segment-list\n .neuroglancer-segment-list-entry:not(:hover)\n .neuroglancer-eye-icon:not(.neuroglancer-visible) {\n visibility: hidden;\n}\n\n.neuroglancer-segment-list-entry-visible-checkbox {\n order: 1;\n}\n\n.neuroglancer-segment-list-entry-filter {\n visibility: hidden;\n grid-column: filter;\n order: 999;\n}\n\n.neuroglancer-segment-list-entry:hover .neuroglancer-segment-list-entry-filter {\n visibility: visible;\n}\n\n.neuroglancer-segment-query-result-tag-list {\n display: grid;\n grid-auto-rows: auto;\n grid-template-columns: [include] min-content [exclude] min-content [tag] 1fr [count] min-content;\n}\n\n.neuroglancer-segment-query-result-tag {\n display: contents;\n}\n\n.neuroglancer-segment-query-result-tag:hover * {\n background-color: #222;\n}\n\n.neuroglancer-segment-query-result-tag-name {\n grid-column: tag;\n white-space: nowrap;\n cursor: pointer;\n font-weight: bold;\n}\n\n.neuroglancer-segment-query-result-tag-name::before {\n content: \"#\";\n color: #aaa;\n font-weight: normal;\n}\n\n.neuroglancer-segment-query-result-tag-toggle {\n display: inline-block;\n white-space: nowrap;\n}\n\n.neuroglancer-segment-query-result-tag-include {\n grid-column: include;\n}\n\n.neuroglancer-segment-query-result-tag-exclude {\n grid-column: exclude;\n}\n\n.neuroglancer-segment-query-result-statistics {\n background-color: #333;\n max-height: 30%;\n flex-shrink: 0;\n overflow: auto;\n}\n\n.neuroglancer-segment-query-result-statistics:not(:empty) {\n padding-top: 3px;\n}\n\n.neuroglancer-segment-query-result-statistics:not(:empty)\n + .neuroglancer-segment-list-status {\n border-top: 1px solid white;\n}\n\n.neuroglancer-segment-query-result-statistics-separator {\n height: 3px;\n background-color: #333;\n border-bottom: 1px solid white;\n}\n\n.neuroglancer-segment-query-result-tag-count {\n grid-column: count;\n text-align: right;\n}\n\n.neuroglancer-segment-query-result-tag-count:not(:empty)::before {\n content: \"(\";\n color: #aaa;\n}\n\n.neuroglancer-segment-query-result-tag-count:not(:empty)::after {\n content: \")\";\n color: #aaa;\n}\n\n.neuroglancer-segment-query-result-numerical-list {\n display: flex;\n flex-direction: column;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-container {\n justify-self: stretch;\n display: flex;\n flex-direction: column;\n padding: 2px;\n}\n\n.neuroglancer-segment-query-result-numerical-plot {\n display: block;\n height: 30px;\n cursor: ew-resize;\n justify-self: stretch;\n border: 1px solid #666;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-bound {\n background-color: transparent;\n border-color: transparent;\n box-shadow: none;\n border: 0;\n margin: 0;\n font: 10pt sans-serif;\n pointer-events: auto;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-window-bound {\n color: cyan;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-range-bound {\n color: white;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-bounds {\n display: flex;\n flex-direction: row;\n color: #aaa;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-bound-constraint-symbol {\n align-self: center;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-bound-constraint-spacer {\n flex: 1;\n color: white;\n font-weight: bold;\n display: flex;\n flex-direction: row;\n justify-content: center;\n align-items: center;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-label {\n cursor: pointer;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-sort,\n.neuroglancer-segment-list-header-label-sort {\n visibility: hidden;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-label:hover\n .neuroglancer-segment-query-result-numerical-plot-sort,\n.neuroglancer-segment-list-header-label:hover\n .neuroglancer-segment-list-header-label-sort {\n visibility: visible;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-container:hover\n .neuroglancer-segment-query-result-numerical-plot-bounds-window {\n visibility: visible;\n}\n\n.neuroglancer-segment-query-result-numerical-plot-bounds-window {\n justify-content: space-between;\n margin-top: -16px;\n visibility: hidden;\n pointer-events: none;\n}\n\n.neuroglancer-segment-list-entry.neuroglancer-segment-list-header {\n background-color: #666;\n}\n\n.neuroglancer-segment-list-header .neuroglancer-segment-list-entry-id {\n background-color: inherit;\n color: white;\n text-align: center;\n}\n\n.neuroglancer-segment-list-header-label {\n cursor: pointer;\n font: 10pt sans-serif;\n}\n\n.neuroglancer-segment-list-header\n .neuroglancer-segment-list-entry-extra-property {\n text-align: center;\n}\n\n.neuroglancer-segment-list-status-message {\n overflow: hidden;\n white-space: nowrap;\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-merge-segments-status {\n display: flex;\n flex-direction: row;\n}\n\n.neuroglancer-merge-segments-status .neuroglancer-segment-list-entry {\n margin-left: 1em;\n margin-right: 1em;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.overlay {\n height: 100%;\n width: 100%;\n position: fixed;\n z-index: 99;\n top: 0;\n left: 0;\n background-color: rgba(0, 0, 0, 0.8);\n}\n\n.overlay-content {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n background-color: white;\n z-index: 100;\n color: black;\n padding: 1em;\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-linked-layer-widget-layer {\n display: flex;\n flex-direction: row;\n}\n\n.neuroglancer-linked-layer-widget-layer:hover {\n background-color: #333;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-shader-code-widget.invalid-input {\n border: 1px solid red;\n}\n\n.neuroglancer-shader-code-widget.valid-input {\n border: 1px solid green;\n}\n\n.neuroglancer-shader-code-widget {\n border: 1px solid transparent;\n}\n","/* BASICS */\n\n.CodeMirror {\n /* Set height, width, borders, and global font properties here */\n font-family: monospace;\n height: 300px;\n color: black;\n direction: ltr;\n}\n\n/* PADDING */\n\n.CodeMirror-lines {\n padding: 4px 0; /* Vertical padding around content */\n}\n.CodeMirror pre.CodeMirror-line,\n.CodeMirror pre.CodeMirror-line-like {\n padding: 0 4px; /* Horizontal padding of content */\n}\n\n.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {\n background-color: white; /* The little square between H and V scrollbars */\n}\n\n/* GUTTER */\n\n.CodeMirror-gutters {\n border-right: 1px solid #ddd;\n background-color: #f7f7f7;\n white-space: nowrap;\n}\n.CodeMirror-linenumbers {}\n.CodeMirror-linenumber {\n padding: 0 3px 0 5px;\n min-width: 20px;\n text-align: right;\n color: #999;\n white-space: nowrap;\n}\n\n.CodeMirror-guttermarker { color: black; }\n.CodeMirror-guttermarker-subtle { color: #999; }\n\n/* CURSOR */\n\n.CodeMirror-cursor {\n border-left: 1px solid black;\n border-right: none;\n width: 0;\n}\n/* Shown when moving in bi-directional text */\n.CodeMirror div.CodeMirror-secondarycursor {\n border-left: 1px solid silver;\n}\n.cm-fat-cursor .CodeMirror-cursor {\n width: auto;\n border: 0 !important;\n background: #7e7;\n}\n.cm-fat-cursor div.CodeMirror-cursors {\n z-index: 1;\n}\n.cm-fat-cursor .CodeMirror-line::selection,\n.cm-fat-cursor .CodeMirror-line > span::selection, \n.cm-fat-cursor .CodeMirror-line > span > span::selection { background: transparent; }\n.cm-fat-cursor .CodeMirror-line::-moz-selection,\n.cm-fat-cursor .CodeMirror-line > span::-moz-selection,\n.cm-fat-cursor .CodeMirror-line > span > span::-moz-selection { background: transparent; }\n.cm-fat-cursor { caret-color: transparent; }\n@-moz-keyframes blink {\n 0% {}\n 50% { background-color: transparent; }\n 100% {}\n}\n@-webkit-keyframes blink {\n 0% {}\n 50% { background-color: transparent; }\n 100% {}\n}\n@keyframes blink {\n 0% {}\n 50% { background-color: transparent; }\n 100% {}\n}\n\n/* Can style cursor different in overwrite (non-insert) mode */\n.CodeMirror-overwrite .CodeMirror-cursor {}\n\n.cm-tab { display: inline-block; text-decoration: inherit; }\n\n.CodeMirror-rulers {\n position: absolute;\n left: 0; right: 0; top: -50px; bottom: 0;\n overflow: hidden;\n}\n.CodeMirror-ruler {\n border-left: 1px solid #ccc;\n top: 0; bottom: 0;\n position: absolute;\n}\n\n/* DEFAULT THEME */\n\n.cm-s-default .cm-header {color: blue;}\n.cm-s-default .cm-quote {color: #090;}\n.cm-negative {color: #d44;}\n.cm-positive {color: #292;}\n.cm-header, .cm-strong {font-weight: bold;}\n.cm-em {font-style: italic;}\n.cm-link {text-decoration: underline;}\n.cm-strikethrough {text-decoration: line-through;}\n\n.cm-s-default .cm-keyword {color: #708;}\n.cm-s-default .cm-atom {color: #219;}\n.cm-s-default .cm-number {color: #164;}\n.cm-s-default .cm-def {color: #00f;}\n.cm-s-default .cm-variable,\n.cm-s-default .cm-punctuation,\n.cm-s-default .cm-property,\n.cm-s-default .cm-operator {}\n.cm-s-default .cm-variable-2 {color: #05a;}\n.cm-s-default .cm-variable-3, .cm-s-default .cm-type {color: #085;}\n.cm-s-default .cm-comment {color: #a50;}\n.cm-s-default .cm-string {color: #a11;}\n.cm-s-default .cm-string-2 {color: #f50;}\n.cm-s-default .cm-meta {color: #555;}\n.cm-s-default .cm-qualifier {color: #555;}\n.cm-s-default .cm-builtin {color: #30a;}\n.cm-s-default .cm-bracket {color: #997;}\n.cm-s-default .cm-tag {color: #170;}\n.cm-s-default .cm-attribute {color: #00c;}\n.cm-s-default .cm-hr {color: #999;}\n.cm-s-default .cm-link {color: #00c;}\n\n.cm-s-default .cm-error {color: #f00;}\n.cm-invalidchar {color: #f00;}\n\n.CodeMirror-composing { border-bottom: 2px solid; }\n\n/* Default styles for common addons */\n\ndiv.CodeMirror span.CodeMirror-matchingbracket {color: #0b0;}\ndiv.CodeMirror span.CodeMirror-nonmatchingbracket {color: #a22;}\n.CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); }\n.CodeMirror-activeline-background {background: #e8f2ff;}\n\n/* STOP */\n\n/* The rest of this file contains styles related to the mechanics of\n the editor. You probably shouldn't touch them. */\n\n.CodeMirror {\n position: relative;\n overflow: hidden;\n background: white;\n}\n\n.CodeMirror-scroll {\n overflow: scroll !important; /* Things will break if this is overridden */\n /* 50px is the magic margin used to hide the element's real scrollbars */\n /* See overflow: hidden in .CodeMirror */\n margin-bottom: -50px; margin-right: -50px;\n padding-bottom: 50px;\n height: 100%;\n outline: none; /* Prevent dragging from highlighting the element */\n position: relative;\n z-index: 0;\n}\n.CodeMirror-sizer {\n position: relative;\n border-right: 50px solid transparent;\n}\n\n/* The fake, visible scrollbars. Used to force redraw during scrolling\n before actual scrolling happens, thus preventing shaking and\n flickering artifacts. */\n.CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {\n position: absolute;\n z-index: 6;\n display: none;\n outline: none;\n}\n.CodeMirror-vscrollbar {\n right: 0; top: 0;\n overflow-x: hidden;\n overflow-y: scroll;\n}\n.CodeMirror-hscrollbar {\n bottom: 0; left: 0;\n overflow-y: hidden;\n overflow-x: scroll;\n}\n.CodeMirror-scrollbar-filler {\n right: 0; bottom: 0;\n}\n.CodeMirror-gutter-filler {\n left: 0; bottom: 0;\n}\n\n.CodeMirror-gutters {\n position: absolute; left: 0; top: 0;\n min-height: 100%;\n z-index: 3;\n}\n.CodeMirror-gutter {\n white-space: normal;\n height: 100%;\n display: inline-block;\n vertical-align: top;\n margin-bottom: -50px;\n}\n.CodeMirror-gutter-wrapper {\n position: absolute;\n z-index: 4;\n background: none !important;\n border: none !important;\n}\n.CodeMirror-gutter-background {\n position: absolute;\n top: 0; bottom: 0;\n z-index: 4;\n}\n.CodeMirror-gutter-elt {\n position: absolute;\n cursor: default;\n z-index: 4;\n}\n.CodeMirror-gutter-wrapper ::selection { background-color: transparent }\n.CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent }\n\n.CodeMirror-lines {\n cursor: text;\n min-height: 1px; /* prevents collapsing before first draw */\n}\n.CodeMirror pre.CodeMirror-line,\n.CodeMirror pre.CodeMirror-line-like {\n /* Reset some styles that the rest of the page might have set */\n -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0;\n border-width: 0;\n background: transparent;\n font-family: inherit;\n font-size: inherit;\n margin: 0;\n white-space: pre;\n word-wrap: normal;\n line-height: inherit;\n color: inherit;\n z-index: 2;\n position: relative;\n overflow: visible;\n -webkit-tap-highlight-color: transparent;\n -webkit-font-variant-ligatures: contextual;\n font-variant-ligatures: contextual;\n}\n.CodeMirror-wrap pre.CodeMirror-line,\n.CodeMirror-wrap pre.CodeMirror-line-like {\n word-wrap: break-word;\n white-space: pre-wrap;\n word-break: normal;\n}\n\n.CodeMirror-linebackground {\n position: absolute;\n left: 0; right: 0; top: 0; bottom: 0;\n z-index: 0;\n}\n\n.CodeMirror-linewidget {\n position: relative;\n z-index: 2;\n padding: 0.1px; /* Force widget margins to stay inside of the container */\n}\n\n.CodeMirror-widget {}\n\n.CodeMirror-rtl pre { direction: rtl; }\n\n.CodeMirror-code {\n outline: none;\n}\n\n/* Force content-box sizing for the elements where we expect it */\n.CodeMirror-scroll,\n.CodeMirror-sizer,\n.CodeMirror-gutter,\n.CodeMirror-gutters,\n.CodeMirror-linenumber {\n -moz-box-sizing: content-box;\n box-sizing: content-box;\n}\n\n.CodeMirror-measure {\n position: absolute;\n width: 100%;\n height: 0;\n overflow: hidden;\n visibility: hidden;\n}\n\n.CodeMirror-cursor {\n position: absolute;\n pointer-events: none;\n}\n.CodeMirror-measure pre { position: static; }\n\ndiv.CodeMirror-cursors {\n visibility: hidden;\n position: relative;\n z-index: 3;\n}\ndiv.CodeMirror-dragcursors {\n visibility: visible;\n}\n\n.CodeMirror-focused div.CodeMirror-cursors {\n visibility: visible;\n}\n\n.CodeMirror-selected { background: #d9d9d9; }\n.CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; }\n.CodeMirror-crosshair { cursor: crosshair; }\n.CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; }\n.CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; }\n\n.cm-searching {\n background-color: #ffa;\n background-color: rgba(255, 255, 0, .4);\n}\n\n/* Used to force a border model for a node */\n.cm-force-border { padding-right: .1px; }\n\n@media print {\n /* Hide the cursor when printing */\n .CodeMirror div.CodeMirror-cursors {\n visibility: hidden;\n }\n}\n\n/* See issue #2901 */\n.cm-tab-wrap-hack:after { content: ''; }\n\n/* Help users use markselection to safely style text background */\nspan.CodeMirror-selectedtext { background: none; }\n","/* The lint marker gutter */\n.CodeMirror-lint-markers {\n width: 16px;\n}\n\n.CodeMirror-lint-tooltip {\n background-color: #ffd;\n border: 1px solid black;\n border-radius: 4px 4px 4px 4px;\n color: black;\n font-family: monospace;\n font-size: 10pt;\n overflow: hidden;\n padding: 2px 5px;\n position: fixed;\n white-space: pre;\n white-space: pre-wrap;\n z-index: 100;\n max-width: 600px;\n opacity: 0;\n transition: opacity .4s;\n -moz-transition: opacity .4s;\n -webkit-transition: opacity .4s;\n -o-transition: opacity .4s;\n -ms-transition: opacity .4s;\n}\n\n.CodeMirror-lint-mark {\n background-position: left bottom;\n background-repeat: repeat-x;\n}\n\n.CodeMirror-lint-mark-warning {\n background-image: url(\"\");\n}\n\n.CodeMirror-lint-mark-error {\n background-image: url(\"\");\n}\n\n.CodeMirror-lint-marker {\n background-position: center center;\n background-repeat: no-repeat;\n cursor: pointer;\n display: inline-block;\n height: 16px;\n width: 16px;\n vertical-align: middle;\n position: relative;\n}\n\n.CodeMirror-lint-message {\n padding-left: 18px;\n background-position: top left;\n background-repeat: no-repeat;\n}\n\n.CodeMirror-lint-marker-warning, .CodeMirror-lint-message-warning {\n background-image: url(\"\");\n}\n\n.CodeMirror-lint-marker-error, .CodeMirror-lint-message-error {\n background-image: url(\"\");\n}\n\n.CodeMirror-lint-marker-multiple {\n background-image: url(\"\");\n background-repeat: no-repeat;\n background-position: right bottom;\n width: 100%; height: 100%;\n}\n\n.CodeMirror-lint-line-error {\n background-color: rgba(183, 76, 81, 0.08);\n}\n\n.CodeMirror-lint-line-warning {\n background-color: rgba(255, 211, 0, 0.1);\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-layer-data-sources-tab {\n display: flex;\n flex-direction: column;\n}\n\n.neuroglancer-layer-data-sources-container {\n overflow-y: auto;\n display: flex;\n flex-direction: column;\n flex: 1;\n height: 0px;\n z-index: 1;\n}\n\n.neuroglancer-layer-data-source-url-input input.autocomplete-input {\n color: #fff;\n}\n\n.neuroglancer-layer-data-source-url-input input.autocomplete-hint {\n color: #aaa;\n}\n\n.neuroglancer-layer-data-source-url-input .autocomplete-dropdown {\n background-color: #333;\n}\n\n.neuroglancer-layer-data-sources-source-id {\n font-weight: bold;\n}\n\n.neuroglancer-layer-data-sources-source-id:not(:empty)::before {\n content: \"[\";\n}\n\n.neuroglancer-layer-data-sources-source-id:not(:empty)::after {\n content: \"]\";\n}\n\n.neuroglancer-layer-data-sources-source-id:not(:empty) {\n margin-right: 4px;\n color: #0ff;\n}\n\n.neuroglancer-layer-data-sources-source-type {\n}\n\n.neuroglancer-layer-data-sources-source-messages:empty {\n display: none;\n}\n\n.neuroglancer-layer-data-sources-source-messages {\n margin-top: 0px;\n list-style: none;\n padding-left: 0px;\n}\n\nli.neuroglancer-message {\n word-wrap: break-word;\n user-select: text;\n}\n\nli.neuroglancer-message-error {\n color: red;\n}\n\nli.neuroglancer-message-warning {\n color: yellow;\n}\n\nli.neuroglancer-message-info {\n color: #ccc;\n}\n\n.neuroglancer-layer-data-sources-source-default {\n display: block;\n margin-bottom: 4px;\n}\n\n.neuroglancer-layer-data-sources-info-line[data-is-active=\"false\"] {\n text-decoration: solid line-through #caa;\n}\n\n.neuroglancer-layer-data-sources-tab-type-detection {\n position: sticky;\n bottom: 0px;\n background-color: #ff9;\n color: black;\n text-align: center;\n cursor: pointer;\n}\n\n.neuroglancer-layer-data-sources-tab-type-detection:hover {\n background-color: #ffc;\n}\n\n.neuroglancer-layer-data-sources-tab-type-detection-type {\n font-weight: bold;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-coordinate-space-transform-widget {\n display: grid;\n justify-items: stretch;\n}\n\n.neuroglancer-coordinate-space-transform-widget input {\n font-family: monospace;\n justify-self: stretch;\n background-color: black;\n color: white;\n padding: 2px;\n}\n\n.neuroglancer-coordinate-space-transform-widget *[data-will-be-deleted=\"true\"] {\n color: #666;\n}\n\n.neuroglancer-coordinate-space-transform-label {\n font-style: italic;\n color: #fcc;\n align-self: center;\n}\n\n.neuroglancer-coordinate-space-transform-input-lower-label {\n grid-row: sourceLower;\n grid-column: outputLabel / sourceDim 1;\n}\n\n.neuroglancer-coordinate-space-transform-translation-label {\n grid-row: sourceLabel / outputDim 1;\n grid-column: sourceDim -1;\n writing-mode: vertical-lr;\n text-orientation: mixed;\n align-self: end;\n justify-self: center;\n margin-bottom: 2px;\n}\n\n.neuroglancer-coordinate-space-transform-input-lower-label,\n.neuroglancer-coordinate-space-transform-input-upper-label,\n.neuroglancer-coordinate-space-transform-input-scale-label {\n text-align: right;\n margin-right: 4px;\n}\n\n.neuroglancer-coordinate-space-transform-input-upper-label {\n grid-row: sourceUpper;\n grid-column: headerStart / headerEnd;\n}\n\n.neuroglancer-coordinate-space-transform-input-scale-label {\n grid-row: 5;\n grid-column: headerStart / headerEnd;\n}\n\n.neuroglancer-coordinate-space-transform-source-label {\n grid-row: sourceLabel;\n grid-column: sourceDim 1 / sourceDim -1;\n text-align: center;\n}\n\n.neuroglancer-coordinate-space-transform-output-label {\n grid-row: outputDim 1 / outputDim -1;\n grid-column: outputLabel;\n writing-mode: vertical-lr;\n text-orientation: mixed;\n align-self: center;\n justify-self: end;\n margin-right: 2px;\n}\n\n.neuroglancer-coordinate-space-transform-input-name {\n text-align: center;\n}\n\n.neuroglancer-coordinate-space-transform-input-name,\ninput.neuroglancer-coordinate-space-transform-output-name {\n font-family: monospace;\n color: #ff6;\n}\n\n.neuroglancer-coordinate-space-transform-scale {\n text-align: right;\n}\n\n.neuroglancer-coordinate-space-transform-input-bounds,\n.neuroglancer-coordinate-space-transform-output-bounds {\n white-space: nowrap;\n font-family: monospace;\n font-size: small;\n text-align: right;\n padding-left: 2px;\n padding-right: 2px;\n color: #aff;\n}\n\n.neuroglancer-coordinate-space-transform-input-bounds.neuroglancer-coordinate-space-transform-singleton:not(\n *[data-will-be-deleted=\"true\"]\n ) {\n color: #fa6;\n}\n\n.neuroglancer-coordinate-space-transform-widget input[data-is-valid=\"false\"],\n.neuroglancer-coordinate-space-transform-widget\n input[data-is-valid=\"false\"]::placeholder {\n text-decoration: solid underline red;\n}\n\n.neuroglancer-coordinate-space-transform-output-extend {\n grid-row: outputDim -1;\n grid-column: outputNames;\n display: flex;\n flex-direction: column;\n}\n\n.neuroglancer-coordinate-space-transform-output-extend input {\n align-self: stretch;\n}\n\n.neuroglancer-coordinate-space-transform-output-extend[data-is-active=\"false\"]\n input {\n display: none;\n}\n\n.neuroglancer-coordinate-space-transform-output-extend[data-is-active=\"true\"]\n .neuroglancer-icon {\n display: none;\n}\n\n.neuroglancer-coordinate-space-transform-output-extend .neuroglancer-icon {\n align-self: start;\n}\n\n.neuroglancer-coordinate-space-transform-translation-coeff {\n margin-left: 3px;\n}\n\n.neuroglancer-coordinate-space-transform-output-scale-container {\n margin-right: 3px;\n}\n\n.neuroglancer-coordinate-space-transform-input-scale-container,\n.neuroglancer-coordinate-space-transform-input-scale-label {\n margin-bottom: 3px;\n}\n\n.neuroglancer-coordinate-space-transform-widget input,\n.neuroglancer-coordinate-space-transform-output-name-container,\n.neuroglancer-coordinate-space-transform-scale-container {\n border: 1px solid #333;\n}\n\n.neuroglancer-coordinate-space-transform-widget\n .neuroglancer-coordinate-space-transform-output-name,\n.neuroglancer-coordinate-space-transform-widget\n .neuroglancer-coordinate-space-transform-scale {\n border: 0px;\n}\n\n.neuroglancer-coordinate-space-transform-output-name-container {\n display: flex;\n flex-direction: column;\n align-items: stretch;\n margin-right: 3px;\n}\n\n.neuroglancer-coordinate-space-transform-scale-container {\n display: flex;\n flex-direction: column;\n align-items: stretch;\n}\n\n.neuroglancer-coordinate-space-transform-scale-suggestion {\n font-family: monospace;\n cursor: pointer;\n border-radius: 20%;\n border: 1px solid #333;\n align-self: flex-end;\n margin: 2px;\n color: #aaa;\n}\n\n.neuroglancer-coordinate-space-transform-scale-suggestion svg {\n width: 16px;\n height: 16px;\n fill: transparent;\n stroke: #aaa;\n stroke-width: 2;\n stroke-linecap: round;\n stroke-linejoin: round;\n}\n\n.neuroglancer-coordinate-space-transform-scale-suggestion:hover {\n background-color: #db4437;\n border: 1px solid transparent;\n color: white;\n}\n\n.neuroglancer-coordinate-space-transform-scale-suggestion:hover svg {\n stroke: white;\n}\n\n.neuroglancer-coordinate-space-transform-widget-reset-buttons {\n grid-row: outputDim -1;\n grid-column: headerEnd / -1;\n justify-self: start;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-multiline-autocomplete {\n margin-top: 2px;\n padding: 2px;\n position: relative;\n background-color: #222;\n}\n\n.neuroglancer-multiline-autocomplete-hint,\n.neuroglancer-multiline-autocomplete-input {\n font-family: monospace;\n color: #fff;\n word-wrap: break-word;\n}\n\n.neuroglancer-multiline-autocomplete-input:focus {\n outline: 0px;\n}\n\n.neuroglancer-multiline-autocomplete-input:not(:focus):empty::before {\n content: attr(data-placeholder);\n color: #aaa;\n}\n\n.neuroglancer-multiline-autocomplete-hint {\n color: #aaa;\n}\n\n.neuroglancer-multiline-autocomplete-hint,\n.neuroglancer-multiline-autocomplete-input,\n.neuroglancer-multiline-autocomplete-completion {\n font-family: monospace;\n font-size: medium;\n}\n\n.neuroglancer-multiline-autocomplete-dropdown {\n color: #fff;\n background-color: #181818;\n position: fixed;\n display: block;\n outline: 0;\n margin: 0;\n padding: 0;\n left: 0px;\n right: 0px;\n text-align: left;\n cursor: default;\n border-style: solid;\n border-width: 1px;\n border-color: #aaa;\n overflow-y: scroll;\n word-wrap: break-word;\n}\n\n.neuroglancer-multiline-autocomplete-completion:nth-child(even):not(\n .neuroglancer-multiline-autocomplete-completion-active\n ) {\n background-color: #2b2b2b;\n}\n\n.neuroglancer-multiline-autocomplete-completion:hover {\n outline: 1px solid #ddd;\n}\n\n.neuroglancer-multiline-autocomplete-completion-active {\n background-color: #666;\n}\n\n.neuroglancer-multiline-autocomplete-completion-with-description {\n}\n\n.neuroglancer-multiline-autocomplete-completion-description {\n font-style: italic;\n color: #f9f;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-image-dropdown {\n overflow-y: auto;\n display: flex;\n flex-direction: column;\n height: 0px;\n}\n\n.neuroglancer-image-dropdown .neuroglancer-shader-code-widget {\n flex-shrink: 0;\n height: 8em;\n border: 1px solid transparent;\n}\n\n.neuroglancer-image-dropdown-top-row {\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.neuroglancer-image-layer-shader-overlay .neuroglancer-shader-code-widget {\n width: 80vw;\n height: 80vh;\n}\n\n.neuroglancer-selection-details-value-grid {\n display: grid;\n grid-auto-rows: auto;\n font-family: monospace;\n font-size: medium;\n align-items: center;\n}\n\n.neuroglancer-selection-details-value-grid-dim {\n grid-column: dim;\n color: #ff6;\n}\n\n.neuroglancer-selection-details-value-grid-dim::after {\n content: \"=\";\n color: #aaa;\n}\n\n.neuroglancer-selection-details-value-grid-coord {\n grid-column: coord;\n color: #aaa;\n margin-right: 1ch;\n}\n\n.neuroglancer-selection-details-value-grid-value {\n grid-column: value;\n user-select: text;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-channel-dimensions-widget-dim {\n display: contents;\n}\n\n.neuroglancer-channel-dimensions-widget {\n display: grid;\n grid-template-columns: [name] min-content [lower] min-content [upper] min-content;\n}\n\n.neuroglancer-channel-dimensions-widget-name-container {\n grid-column: name;\n}\n\n.neuroglancer-channel-dimensions-widget-name[data-is-valid=\"false\"],\n.neuroglancer-channel-dimensions-widget-name::placeholder {\n text-decoration: solid underline red;\n}\n\n.neuroglancer-channel-dimensions-widget-name {\n background-color: transparent;\n border-color: transparent;\n box-shadow: none;\n border: 0;\n margin: 0;\n font-family: monospace;\n font-size: medium;\n color: #ff6;\n}\n\n.neuroglancer-channel-dimensions-widget-name,\n.neuroglancer-channel-dimensions-widget-lower,\n.neuroglancer-channel-dimensions-widget-upper {\n font-family: monospace;\n}\n\n.neuroglancer-channel-dimensions-widget-lower {\n grid-column: lower;\n text-align: right;\n}\n\n.neuroglancer-channel-dimensions-widget-upper {\n grid-column: upper;\n text-align: right;\n}\n\n.neuroglancer-channel-dimensions-widget-lower,\n.neuroglancer-channel-dimensions-widget-upper {\n text-align: right;\n margin-left: 1ch;\n user-select: text;\n}\n\n.neuroglancer-channel-dimensions-widget-upper::after {\n content: \")\";\n}\n\n.neuroglancer-channel-dimensions-widget-lower::after {\n content: \",\";\n}\n\n.neuroglancer-channel-dimensions-widget-lower::before {\n content: \"[\";\n}\n\n.neuroglancer-channel-dimensions-widget-upper::after,\n.neuroglancer-channel-dimensions-widget-lower::before,\n.neuroglancer-channel-dimensions-widget-lower::after {\n color: #999;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-single-mesh-dropdown .neuroglancer-single-mesh-attribute-widget {\n max-height: 6em;\n margin-bottom: 8px;\n}\n\n.neuroglancer-single-mesh-dropdown .neuroglancer-shader-code-widget {\n height: 6em;\n width: 60ch;\n border: 1px solid transparent;\n}\n\n.neuroglancer-single-mesh-dropdown-top-row {\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.neuroglancer-single-mesh-shader-overlay .neuroglancer-shader-code-widget {\n width: 80vw;\n height: 80vh;\n}\n\n.neuroglancer-single-mesh-attribute-widget {\n word-wrap: break-word;\n overflow-y: auto;\n display: grid;\n grid-template-columns: [type] auto [name] auto [range] auto;\n}\n\n.neuroglancer-single-mesh-layer-shader-overlay\n .neuroglancer-single-mesh-attribute-widget {\n max-height: 20vh;\n}\n\n.neuroglancer-single-mesh-attribute {\n font-family: monospace;\n display: contents;\n}\n\n.neuroglancer-single-mesh-attribute-type {\n color: #c6c;\n grid-column: type;\n}\n\n.neuroglancer-single-mesh-attribute-name {\n margin-left: 1ch;\n color: white;\n grid-column: name;\n user-select: text;\n}\n\n.neuroglancer-single-mesh-attribute-range {\n grid-column: range;\n margin-left: 1ch;\n white-space: nowrap;\n color: #999;\n grid-column: range;\n}\n",".neuroglancer-graphene-tab .neuroglancer-annotation-toolbox {\n display: none;\n}\n\n.neuroglancer-graphene-tab\n div[data-color=\"#ff0000\"]\n > .neuroglancer-annotation-position {\n color: red;\n}\n\n.neuroglancer-graphene-tab\n div[data-color=\"#0000ff\"]\n > .neuroglancer-annotation-position {\n color: #4444ff;\n}\n\n.graphene-tool-status {\n display: flex;\n gap: 10px;\n}\n\n.graphene-multicut > .activeGroupIndicator {\n padding: 2px;\n margin: auto 0;\n background-color: red;\n font: 12px sans-serif;\n font-weight: 900;\n}\n\n.graphene-multicut > .activeGroupIndicator.blueGroup {\n background-color: blue;\n}\n\n.graphene-multicut > .activeGroupIndicator::after {\n content: \"Red\";\n}\n\n.graphene-multicut > .activeGroupIndicator.blueGroup::after {\n content: \"Blue\";\n}\n\n.graphene-merge-segments-merges {\n display: flex;\n flex-direction: column;\n}\n\n.graphene-merge-segments-submission {\n display: flex;\n gap: 10px;\n}\n\n.graphene-tool-status .neuroglancer-icon {\n height: 100%;\n}\n\n.graphene-merge-segments-status label {\n display: grid;\n grid-template-columns: min-content min-content;\n white-space: nowrap;\n justify-content: center;\n align-content: center;\n}\n\n.graphene-merge-segments-point {\n display: flex;\n align-items: center;\n gap: 10px;\n}\n\n.graphene-merge-segments-point\n .neuroglancer-segment-list-entry-visible-checkbox,\n.graphene-merge-segments-point .neuroglancer-segment-list-entry-copy-container {\n display: none;\n}\n\n.graphene-find-path > label {\n display: flex;\n}\n\n.graphene-find-path > label > span {\n display: flex;\n align-content: center;\n flex-wrap: wrap;\n}\n\n.find-path-annotations {\n display: flex;\n gap: 10px;\n}\n\n.find-path-annotations > .neuroglancer-annotation-list-entry {\n background-color: black;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nhtml,\nbody {\n margin: 0px;\n padding: 0px;\n overflow: hidden;\n width: 100vw;\n height: 100vh;\n background-color: black;\n color: white;\n}\n\nbody {\n position: relative;\n display: flex;\n flex-direction: column;\n}\n\n#neuroglancer-container {\n width: 100vw;\n overflow: hidden;\n flex: 1;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-viewer {\n outline: 0px;\n}\n\n.neuroglancer-viewer-top-row {\n display: flex;\n flex-direction: row;\n align-items: center;\n background-color: #222;\n margin-bottom: 3px;\n padding-right: 2px;\n}\n\n.neuroglancer-viewer-side-panel {\n display: flex;\n flex-direction: column;\n align-items: stretch;\n max-width: 80%;\n color: #fff;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-noselect {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -khtml-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n}\n\n.neuroglancer-select-text {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -khtml-user-select: text;\n -moz-user-select: text;\n -ms-user-select: text;\n user-select: text;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-data-panel-layout-controls {\n position: absolute;\n top: 2px;\n right: 2px;\n display: flex;\n align-items: start;\n}\n\n.neuroglancer-data-panel-layout-controls > button {\n display: flex;\n margin: 2px;\n border: 0px;\n background-color: rgba(0, 0, 0, 0.5);\n flex-direction: row;\n align-self: top;\n align-items: center;\n justify-content: center;\n border: 1px solid white;\n font-size: 15px;\n width: 18px;\n height: 18px;\n color: white;\n}\n\n.neuroglancer-data-panel-layout-controls > button > div {\n display: inline-block;\n text-align: center;\n line-height: 12px;\n width: 15px;\n height: 15px;\n}\n\n.neuroglancer-data-panel-layout-controls > button:hover {\n color: #6ff;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nlabel.perspective-panel-show-slice-views {\n pointer-events: none;\n position: absolute;\n right: 2px;\n bottom: 2px;\n font-family: sans-serif;\n font-size: small;\n}\n\ninput.perspective-panel-show-slice-views {\n pointer-events: all;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-rendered-data-panel {\n cursor: crosshair;\n position: relative;\n outline: 0;\n touch-action: none;\n color: #fff;\n text-align: left;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-display-dimensions-widget {\n position: absolute;\n cursor: default;\n top: 2px;\n left: 2px;\n background-color: rgba(0, 0, 0, 0.3);\n}\n\n.neuroglancer-display-dimensions-widget-dimension-grid {\n display: grid;\n grid-template-rows: 0fr 0fr 0fr 0fr;\n grid-template-columns: 0fr 0fr 0fr;\n}\n\n.neuroglancer-display-dimensions-widget input {\n outline: 0px;\n background-color: transparent;\n border-color: transparent;\n box-shadow: none;\n margin: 0;\n border: 0;\n padding: 2px;\n}\n\n.neuroglancer-display-dimensions-widget input,\n.neuroglancer-display-dimensions-widget {\n font-family: monospace;\n color: white;\n}\n\n.neuroglancer-display-dimensions-widget-dimension:hover {\n outline: 1px solid black;\n}\n\n.neuroglancer-display-dimensions-widget-name[data-is-valid=\"false\"] {\n text-decoration: solid underline red;\n}\n\n.neuroglancer-display-dimensions-widget-scale-factor {\n text-align: right;\n align-items: end;\n display: inline-block;\n white-space: nowrap;\n margin-left: 2px;\n}\n\n.neuroglancer-display-dimensions-widget-scale {\n display: inline-block;\n white-space: nowrap;\n padding-left: 10px;\n}\n\n.neuroglancer-display-dimensions-widget-scale:not(:empty)::before {\n content: \"(\";\n}\n\n.neuroglancer-display-dimensions-widget-scale:not(:empty)::after {\n content: \")\";\n}\n\n.neuroglancer-display-dimensions-widget-scale-factor::after {\n content: \"×\";\n}\n\n.neuroglancer-display-dimensions-widget-scale {\n text-align: right;\n margin-left: 5px;\n}\n\n.neuroglancer-display-dimensions-widget:not(:hover):not([data-active=\"true\"])\n .neuroglancer-display-dimensions-widget-scale-factor,\n.neuroglancer-display-dimensions-widget:not(:hover):not([data-active=\"true\"])\n .neuroglancer-display-dimensions-widget-scale,\n.neuroglancer-display-dimensions-widget:not(:hover):not([data-active=\"true\"])\n .neuroglancer-display-dimensions-widget-default,\n.neuroglancer-display-dimensions-widget:not(:hover):not([data-active=\"true\"])\n .neuroglancer-depth-range-widget-grid,\n.neuroglancer-display-dimensions-widget:not(:hover):not([data-active=\"true\"])\n .neuroglancer-depth-range-relative-checkbox-label {\n display: none;\n}\n\n.neuroglancer-display-dimensions-widget-dimension[data-is-modified=\"true\"]\n .neuroglancer-display-dimensions-widget-scale-factor,\n.neuroglancer-display-dimensions-widget-dimension[data-is-modified=\"true\"]\n .neuroglancer-display-dimensions-widget-scale {\n visibility: hidden;\n}\n\n.neuroglancer-display-dimensions-widget *:focus {\n outline: 0px;\n}\n\n.neuroglancer-display-dimensions-widget-default {\n grid-row: 4;\n grid-column-start: 1;\n grid-column-end: 3;\n display: inline-block;\n white-space: nowrap;\n}\n\n.neuroglancer-display-dimensions-widget-default input {\n margin-right: 3px;\n}\n\n.neuroglancer-depth-range-widget-grid {\n margin-top: 1em;\n display: grid;\n display: grid;\n grid-template-columns: 0fr 0fr 0fr;\n grid-auto-rows: 0fr;\n}\n\n.neuroglancer-depth-range-widget-dimension-names:not(:empty)::before {\n content: \"(\";\n}\n\n.neuroglancer-depth-range-widget-dimension-names:not(:empty)::after {\n content: \")\";\n}\n\n.neuroglancer-depth-range-widget-dimension-names {\n margin-left: 1ch;\n white-space: nowrap;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-help-body {\n flex-basis: 0px;\n flex: 1;\n height: 0px;\n min-height: 0px;\n font-family: sans-serif;\n display: flex;\n flex-direction: column;\n}\n\n.neuroglancer-help-scroll-container {\n flex: 1;\n flex-basis: 0px;\n position: relative;\n overflow: auto;\n}\n\n.neuroglancer-help-scroll-container div + h2 {\n margin-top: 1em;\n}\n\n.neuroglancer-help-scroll-container h2 {\n font-size: 10pt;\n padding: 4px;\n position: sticky;\n top: 0;\n background-color: #333;\n margin-top: 0px;\n}\n\n.neuroglancer-help-scroll-container .dt {\n font-family: monospace;\n font-weight: bold;\n color: yellow;\n}\n\n.neuroglancer-help-scroll-container .dd {\n font-size: 10pt;\n margin-left: 4ex;\n}\n\n.neuroglancer-build-info {\n font-size: 10pt;\n user-select: text;\n}\n\n.neuroglancer-build-info a {\n color: white;\n text-decoration: none;\n font-weight: bold;\n}\n\n.neuroglancer-build-info a:hover {\n background-color: #db4437;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-panel {\n flex: 1;\n}\n\n.neuroglancer-show-panel-borders .neuroglancer-panel {\n border-style: solid;\n border-color: black;\n border-width: 2px;\n}\n\n.neuroglancer-panel:focus-within {\n border-color: white;\n}\n\n.neuroglancer-layer-group-viewer {\n outline: 0px;\n}\n\n.neuroglancer-layer-group-viewer-context-menu {\n flex-direction: column;\n align-items: stretch;\n}\n\n.neuroglancer-layer-group-viewer-context-menu label {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n}\n\n.neuroglancer-layer-group-viewer-context-menu select::before {\n flex: 1;\n content: \" \";\n}\n\n.neuroglancer-layer-group-viewer-context-menu select {\n margin-left: 5px;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-context-menu {\n position: absolute;\n z-index: 100;\n border: 1px solid white;\n background-color: black;\n box-shadow: 5px 5px 2px 1px rgba(0, 0, 0, 0.5);\n font-family: sans-serif;\n font-size: 11pt;\n padding: 5px;\n color: white;\n outline: 0px;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n:root {\n --layer-number-color: #9a7518;\n}\n\n.neuroglancer-layer-panel {\n width: 100%;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n align-items: stretch;\n margin-left: -5px;\n margin-top: -1px;\n z-index: -0.1;\n}\n\n.neuroglancer-layer-item {\n position: relative;\n display: flex;\n align-items: center;\n color: white;\n cursor: pointer;\n border-width: 1px;\n border-style: solid;\n border-color: #ccc;\n font-family: sans-serif;\n font-size: 10pt;\n background-color: black;\n padding: 1px;\n}\n\n.neuroglancer-layer-item,\n.neuroglancer-layer-add-button {\n margin: 1px;\n margin-left: 5px;\n}\n\n.neuroglancer-layer-item[data-selected=\"true\"] {\n border-color: #8c8;\n}\n\n.neuroglancer-layer-item[data-selected=\"true\"]:hover {\n border-color: #3c3;\n}\n\n.neuroglancer-layer-item:hover {\n border-color: #daa520;\n}\n\n.neuroglancer-layer-item[data-pick=\"true\"] .neuroglancer-layer-item-label {\n background-color: #939;\n}\n\n.neuroglancer-layer-item-label {\n display: inline-block;\n position: relative;\n background-color: #222;\n padding-right: 3px;\n}\n\n.neuroglancer-layer-item-number {\n display: inline-block;\n background-color: var(--layer-number-color);\n font-weight: bold;\n padding-left: 1px;\n padding-right: 1px;\n}\n\n.neuroglancer-layer-panel[data-show-hover-values=\"true\"]\n .neuroglancer-layer-item-value {\n display: inline-block;\n font-family: monospace;\n font-size: medium;\n max-width: 50ch;\n margin-left: 1ch;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipses;\n text-align: center;\n}\n\n.neuroglancer-layer-panel[data-show-hover-values=\"false\"]\n .neuroglancer-layer-item-value {\n display: none;\n}\n\n.neuroglancer-layer-item[data-visible=\"false\"] .neuroglancer-layer-item-label {\n text-decoration: line-through;\n}\n\n.neuroglancer-layer-item[data-visible=\"false\"] {\n color: #bbb;\n}\n\n.neuroglancer-layer-panel-drop-zone {\n display: inline-block;\n flex: 1;\n}\n\n.neuroglancer-layer-item-visible-progress,\n.neuroglancer-layer-item-prefetch-progress {\n position: absolute;\n left: 0px;\n height: 2px;\n background-color: #666;\n}\n\n.neuroglancer-layer-item-visible-progress {\n top: 0px;\n}\n\n.neuroglancer-layer-item-prefetch-progress {\n bottom: 0px;\n}\n\n.neuroglancer-layer-item-value-container {\n display: grid;\n grid-template-columns: min-content;\n align-items: center;\n}\n\n.neuroglancer-layer-item-value {\n grid-row: 1;\n grid-column: 1;\n visibility: visible;\n}\n\n.neuroglancer-layer-item-button-container {\n grid-row: 1;\n grid-column: 1;\n white-space: nowrap;\n display: flex;\n flex-direction: row;\n align-items: center;\n visibility: hidden;\n justify-self: right;\n}\n\n.neuroglancer-layer-panel:hover .neuroglancer-layer-item-value {\n visibility: hidden;\n}\n\n.neuroglancer-layer-panel:hover .neuroglancer-layer-item-button-container {\n visibility: visible;\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-layout-split-drop-zone {\n position: absolute;\n z-index: 1000;\n}\n\n.neuroglancer-drag-over {\n background-color: rgba(0, 0, 255, 0.5);\n}\n\n.neuroglancer-stack-layout-row > .neuroglancer-stack-layout-drop-placeholder {\n padding-left: 4px;\n padding-right: 4px;\n width: 1px;\n cursor: col-resize;\n}\n\n.neuroglancer-stack-layout-column\n > .neuroglancer-stack-layout-drop-placeholder {\n padding-top: 4px;\n padding-bottom: 4px;\n height: 1px;\n cursor: row-resize;\n}\n\n.neuroglancer-stack-layout-drop-placeholder {\n background-clip: content-box;\n background-color: #666;\n z-index: 1;\n}\n\n.neuroglancer-stack-layout-drop-placeholder.neuroglancer-drag-over {\n background-clip: border-box;\n background-color: rgba(128, 128, 255, 0.5);\n}\n\n.neuroglancer-stack-layout-drop-placeholder:first-child,\n.neuroglancer-stack-layout-drop-placeholder:last-child {\n display: none;\n}\n",".neuroglancer-layer-list-panel-items {\n display: flex;\n flex-direction: column;\n flex: 1;\n overflow: auto;\n height: 0px;\n min-height: 0px;\n flex-basis: 0px;\n}\n\n.neuroglancer-layer-list-panel-item {\n display: flex;\n flex-direction: row;\n padding: 2px;\n border: 1px solid #aaa;\n margin: 2px;\n}\n\n.neuroglancer-layer-list-panel-item[data-selected=\"true\"] {\n border-color: #3c3;\n}\n\n.neuroglancer-layer-list-panel-item[data-archived=\"true\"] {\n border-color: #666;\n}\n\n.neuroglancer-layer-list-panel-item[data-archived=\"true\"]\n .neuroglancer-layer-side-panel-name,\n.neuroglancer-layer-list-panel-item[data-archived=\"true\"]\n .neuroglancer-icon\n svg {\n color: #999;\n stroke: #999;\n}\n\n.neuroglancer-layer-list-panel-item:hover {\n background-color: #333;\n}\n\n.neuroglancer-layer-list-panel-item-number {\n font-family: sans-serif;\n background-color: var(--layer-number-color);\n color: white;\n font-weight: bold;\n display: inline-block;\n}\n\n.neuroglancer-layer-list-panel-item:not(:hover)\n > .neuroglancer-layer-list-panel-item-delete {\n display: none;\n}\n\n.neuroglancer-layer-list-panel-item:not(:hover)\n > .neuroglancer-layer-list-panel-item-controls {\n display: none;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n[data-neuroglancer-layer-panel-pinned=\"false\"]\n .neuroglancer-side-panel-titlebar.neuroglancer-layer-side-panel-title {\n background-color: #393;\n}\n\n[data-neuroglancer-layer-visible=\"false\"]\n .neuroglancer-side-panel-titlebar.neuroglancer-layer-side-panel-title\n input {\n text-decoration: line-through;\n}\n\n.neuroglancer-layer-side-panel-name {\n flex: 1;\n background-color: transparent;\n border: 0px;\n color: white;\n outline: 0px;\n /* ensure if name gets too long it doesn't push buttons over */\n width: 0px;\n min-width: 0px;\n}\n\n.neuroglancer-layer-side-panel-tab-view {\n flex: 1;\n display: flex;\n flex-direction: column;\n font: 10pt sans-serif;\n}\n\n.neuroglancer-layer-side-panel-type-measure {\n position: absolute;\n visibility: hidden;\n top: 0px;\n height: auto;\n width: auto;\n white-space: nowrap;\n}\n\n.neuroglancer-layer-side-panel-type,\n.neuroglancer-layer-side-panel-type-measure {\n padding-left: 3px;\n padding-right: 3px;\n font-weight: bold;\n font-family: sans-serif;\n font-size: 10pt;\n box-sizing: border-box;\n}\n\n.neuroglancer-layer-side-panel-type {\n -webkit-appearance: none;\n color: white;\n cursor: pointer;\n background-color: rgba(0, 0, 0, 0.5);\n margin-right: 5px;\n border: 0px;\n outline: 0px;\n}\n\n.neuroglancer-layer-side-panel-type option {\n background-color: #000;\n}\n",".CodeMirror-foldmarker {\n color: blue;\n text-shadow: #b9f 1px 1px 2px, #b9f -1px -1px 2px, #b9f 1px -1px 2px, #b9f -1px 1px 2px;\n font-family: arial;\n line-height: .3;\n cursor: pointer;\n}\n.CodeMirror-foldgutter {\n width: .7em;\n}\n.CodeMirror-foldgutter-open,\n.CodeMirror-foldgutter-folded {\n cursor: pointer;\n}\n.CodeMirror-foldgutter-open:after {\n content: \"\\25BE\";\n}\n.CodeMirror-foldgutter-folded:after {\n content: \"\\25B8\";\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-state-editor {\n width: 80%;\n}\n\n.close-button {\n position: absolute;\n right: 15px;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-statistics-panel-body {\n flex: 1;\n flex-basis: 0px;\n min-width: 0px;\n display: flex;\n flex-direction: column;\n overflow-y: auto;\n font: 10pt sans-serif;\n}\n\n.neuroglancer-statistics-panel-body > table {\n position: relative;\n flex: 1;\n width: 100%;\n}\n\n.neuroglancer-statistics-panel-body > table > thead td {\n position: sticky;\n top: 0px;\n z-index: 2;\n background-color: #333;\n font-weight: bold;\n}\n\n.neuroglancer-statistics-panel-body > table > tbody tr:hover {\n background-color: #336;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-settings-body {\n flex-basis: 0px;\n flex: 1;\n height: 0px;\n min-height: 0px;\n font-family: sans-serif;\n display: flex;\n flex-direction: column;\n font-size: 10pt;\n}\n\n.neuroglancer-settings-body input[type=\"text\"],\n.neuroglancer-settings-body input[type=\"number\"] {\n background-color: #333;\n color: #fff;\n border: 0px;\n}\n\n.neuroglancer-settings-scroll-container {\n flex: 1;\n flex-basis: 0px;\n position: relative;\n overflow: auto;\n display: flex;\n flex-direction: column;\n}\n\n.neuroglancer-settings-scroll-container > * {\n margin-top: 3px;\n}\n\n.neuroglancer-settings-title {\n align-self: stretch;\n}\n\n.neuroglancer-settings-scroll-container > label {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n}\n\n.neuroglancer-settings-scroll-container > label > input::before {\n flex: 1;\n content: \" \";\n}\n\n.neuroglancer-settings-scroll-container > label > input {\n margin-left: 5px;\n width: 11ch;\n}\n\n.neuroglancer-settings-limit-widget > input {\n width: 11ch;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n.neuroglancer-annotation-tool-status {\n display: flex;\n flex-direction: row;\n align-items: center;\n overflow-x: scroll;\n scrollbar-width: none;\n}\n\n.neuroglancer-annotation-tool-status::-webkit-scrollbar {\n display: none;\n}\n\n.neuroglancer-annotation-tool-status-widget\n + .neuroglancer-annotation-tool-status-widget {\n margin-left: 3px;\n}\n\n.neuroglancer-annotation-tool-status-widget:hover {\n outline: 1px solid #fff;\n}\n\n.neuroglancer-annotation-tool-status-widget {\n display: flex;\n flex-direction: row;\n align-items: center;\n}\n\n.neuroglancer-annotation-tool-status-widget-layer-number {\n display: inline-block;\n font: 10pt sans-serif;\n font-weight: bold;\n background-color: #9a7518;\n}\n\n.neuroglancer-annotation-tool-status-widget-key {\n display: inline-block;\n font: 9pt monospace;\n color: #0ff;\n}\n\n.neuroglancer-annotation-tool-status-widget-key::before {\n content: \"[\";\n}\n\n.neuroglancer-annotation-tool-status-widget-key::after {\n content: \"]\";\n}\n\n.neuroglancer-annotation-tool-status-widget-key::before,\n.neuroglancer-annotation-tool-status-widget-key::after {\n color: #999;\n}\n\n.neuroglancer-annotation-tool-status-widget-description {\n display: inline-block;\n color: #3c3;\n font: 10pt sans-serif;\n white-space: nowrap;\n}\n\n.neuroglancer-annotation-tool-status-widget-delete {\n visibility: hidden;\n}\n\n.neuroglancer-annotation-tool-status-widget:hover\n > .neuroglancer-annotation-tool-status-widget-delete {\n visibility: inherit;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.js b/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.js new file mode 100644 index 0000000..c575aad --- /dev/null +++ b/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.js @@ -0,0 +1,6132 @@ +var Wb={4242:(se,Ee,G)=>{G.d(Ee,{G1:()=>C,YR:()=>fe,y6:()=>F});var _=G(8796);/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var F=(ye=>(ye[ye.MIN_REPRESENTATIVE=0]="MIN_REPRESENTATIVE",ye[ye.MAX_REPRESENTATIVE=1]="MAX_REPRESENTATIVE",ye[ye.REPRESENTATIVE_EXCLUDED=2]="REPRESENTATIVE_EXCLUDED",ye[ye.NONREPRESENTATIVE_EXCLUDED=4]="NONREPRESENTATIVE_EXCLUDED",ye))(F||{});function fe(ye){return!(ye.high>>>31)}const C=new _.R(4294967295,4294967295)},3206:(se,Ee,G)=>{G.d(Ee,{B0:()=>C,DN:()=>ye,DY:()=>J,Kk:()=>We,Uq:()=>Ie,W1:()=>R,XZ:()=>ne,_Y:()=>ze,aM:()=>q,no:()=>Be,ol:()=>ge,pz:()=>me,rG:()=>B,wP:()=>tt,ww:()=>Dt});var _=G(5716),F=G(2596),fe=G(4038);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class C{constructor(M){this.value_=M,this.changed=new fe.IY}get value(){return this.value_}set value(M){M!==this.value_&&(this.value_=M,this.changed.dispatch())}}class ye extends C{constructor(M,T,U=M){super(M),this.validator=T,this.defaultValue=U}toJSON(){const{value_:M}=this;if(M!==this.defaultValue)return this.value_}reset(){this.value=this.defaultValue}restoreState(M){if(M!==void 0){const{validator:T}=this;try{this.value=T(M);return}catch{}}this.value=this.defaultValue}}class Le extends F.O8{constructor(M,T){super(),this.changed=new fe.IY,this.f=M,this.ws=T;for(const U of T)this.registerDisposer(U.changed.add(this.changed.dispatch))}get value(){return this.f(...this.ws.map(M=>M.value))}}function We($,...M){return new Le($,M)}class Ve extends F.O8{constructor(M,T){super(),this.changed=new fe.IY,this.valueGeneration=-1,this.f=M,this.ws=T;for(const U of T)this.registerDisposer(U.changed.add(this.changed.dispatch))}get value(){const M=this.changed.count;return M!==this.valueGeneration&&(this.value_=this.f(...this.ws.map(T=>T.value)),this.valueGeneration=M),this.value_}}function ge($,...M){return new Ve($,M)}class me extends F.O8{constructor(M,T=(U,ee)=>U===ee){super(),this.changed=new fe.HN,this.value=M.value,this.registerDisposer(M.changed.add(()=>{const U=M.value;T(this.value,U)||(this.value=U,this.changed.dispatch())}))}}function Ie($,M,T){const U=new Le($,M),ee=new me(U,T);return ee.registerDisposer(U),ee}class tt extends F.O8{constructor(M){super(),this.changed=new fe.IY;const T=M(this),U=Object.keys(T),ee=()=>{const te=Array.isArray(T)?[]:{};for(const ve of U)te[ve]=T[ve].value;this.value=te,this.changed.dispatch()};ee();for(const te of U){const ve=T[te];this.registerDisposer(ve.changed.add(()=>ee()))}}}class Dt extends F.O8{constructor(M,...T){super(),this.f=M,this.changed=new fe.IY;for(const U of T)this.registerDisposer(U.add(this.changed.dispatch))}get value(){return this.f()}}class Ge extends F.O8{constructor(){super(...arguments),this.changed=new fe.IY}get value(){return this.value_}set value(M){const{value_:T}=this;if(this.value_=M,T!==void 0&&(T.dispose(),T.unregisterDisposer(this.valueHandler),this.valueHandler=void 0),M!==void 0){const U=this.valueHandler=()=>{this.value_===M&&(this.value_=void 0,this.changed.dispatch())};M.registerDisposer(U)}M!==T&&this.changed.dispatch()}reset(){this.value=void 0}disposed(){this.value_!==void 0&&(this.value_.unregisterDisposer(this.valueHandler),this.value_.dispose()),this.value_=void 0,super.disposed()}}class It extends Ge{constructor(M,T){super(),this.validator=M,this.jsonConverter=T}toJSON(){const{value:M}=this;return M&&this.jsonConverter(M)}restoreState(M){this.value=this.validator(M)}}class ze{constructor(M){this.changed=new fe.HN,M===void 0?this.values=new Set:this.values=new Set(M)}add(M){const{values:T}=this;return T.has(M)||(T.add(M),this.changed.dispatch(M,!0)),this}delete(M){const{values:T}=this;return T.delete(M)?(this.changed.dispatch(M,!1),!0):!1}has(M){return this.values.has(M)}get size(){return this.values.size}[Symbol.iterator](){return this.values[Symbol.iterator]()}clear(){const{values:M}=this;M.size>0&&(M.clear(),this.changed.dispatch(null,!1))}}function Be($,...M){const T=M.map(Xe=>Xe.value),U=M.length;let ee=new F.O8,te=$(ee,...T);const ve=(0,_.A)(()=>{let Xe=!1;for(let He=0;HeXe.changed.add(ve));return{flush(){ve.flush()},dispose(){ve.cancel(),(0,F.$F)(qe),ee.dispose()},get value(){return ve.flush(),te}}}function q($,...M){const T=M.map(Xe=>Xe.value),U=M.length;let ee=new F.O8,te=$(ee,...T);const ve=()=>{let Xe=!1;for(let He=0;HeXe.changed.add(ve));return{dispose(){(0,F.$F)(qe),ee.dispose()},get value(){return te}}}function ne($){return{changed:fe.$$,value:$}}function R($,M){return $(M.value),M.changed.add(()=>$(M.value))}function ae($,M){return M.value=$.value,$.changed.add(()=>{M.value=$.value})}class B{constructor(M,T){this.outer=M,this.getInner=T,this.changed=new fe.IY,this.update=()=>{const{disposer:U,outer:ee}=this;U!==void 0&&U();const te=this.inner=this.getInner(ee.value);this.disposer=te.changed.add(this.changed.dispatch),this.changed.dispatch()},M.changed.add(this.update),this.update()}dispose(){this.outer.changed.remove(this.update),this.disposer()}get value(){return this.inner.value}set value(M){this.inner.value=M}}class J extends B{reset(){this.inner.reset()}restoreState(M){this.inner.restoreState(M)}toJSON(){return this.inner.toJSON()}}},4037:(se,Ee,G)=>{G.d(Ee,{CS:()=>Le,El:()=>We,Lp:()=>Ve,NT:()=>ae,RO:()=>Be,U8:()=>F,ak:()=>R,b8:()=>ze,eL:()=>q,eN:()=>me,ep:()=>Ge,jx:()=>fe,lX:()=>ge,r1:()=>tt,wm:()=>Dt});/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function _(B,J,$,M){for(;J<$;){const T=B[J];if(M(T)){++J;continue}--$,B[J]=B[$],B[$]=T}return $}function F(B,J){const $=B.length;let M=0;for(let T=0;T<$;++T)J(B[T],T,B)&&(B[M]=B[T],++M);B.length=M}function fe(B,J){if(B.length===J)return B;const $=new B.constructor(J);return $.set(B),$}function C(B,J=1){const $=B.length,M=new Array($);let T=M[0]=J;for(let U=1;U<$;++U)T*=B[U-1],M[U]=T;return M}function ye(B,J,$){const M=new B.constructor(B.length);for(let T=0;T>1,ee=$(J,B[U]);if(ee>0)M=U+1;else if(ee<0)T=U;else return U}return~M}function Ve(B,J,$,M=0,T=B.length){let U=-1,ee=1/0;for(;M>1,ve=$(J,B[te]);if(ve>0)M=te+1;else if(ve<0)T=te;else return te;const qe=Math.abs(ve);qe0;){const T=Math.floor(M/2),U=B+T;$(U)?M=T:(B=U+1,M-=T+1)}return B}function me(B,J){const $=[];for(let M=0,T=B.length;MM===T){const M=B.length;if(J.length!==M)return!1;for(let T=0;T0){let He=1;for(;++U0;)++He;M.push({retainCount:0,deleteCount:0,insertCount:He})}}return(T0){if(T(te),++te===J)break}else if(U(ee,te),++ee,++te,ee===B||te===J)break}for(;ee{G.d(Ee,{Dq:()=>fe,Qi:()=>Le,fx:()=>ye,gI:()=>Ve,wS:()=>F,y3:()=>We});/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class _ extends Error{constructor(){super(...arguments),this.name="CancellationError",this.message="CANCELED"}toString(){return"CANCELED"}}const F=new _;function fe(ge){if(ge.isCanceled===!0)throw F}const C=()=>{},ye={isCanceled:!1,add:()=>C,remove:C};class Le{cancel(){const{handlers:me}=this;if(me!==null&&(this.handlers=null,me!==void 0))for(const Ie of me)Ie()}get isCanceled(){return this.handlers===null}add(me){let{handlers:Ie}=this;return Ie===null?(me(),C):(Ie===void 0&&(Ie=this.handlers=new Set),Ie.add(me),()=>{this.remove(me)})}remove(me){const{handlers:Ie}=this;Ie?.delete(me)}}class We extends Le{constructor(){super(...arguments),this.consumers=new Set}addConsumer(me=ye){const{consumers:Ie}=this;Ie.has(me)||me.isCanceled||(Ie.add(me),me.add(()=>{Ie.delete(me),Ie.size===0&&this.cancel()}))}}function Ve(ge,me){return new Promise((Ie,tt)=>{if(ge===ye){me(Ie,tt,ye);return}const Dt=new Le,Ge=ge.add(()=>{Dt.cancel()});me(It=>{Ge(),Ie(It)},It=>{Ge(),tt(It)},Dt)})}},2596:(se,Ee,G)=>{G.d(Ee,{$F:()=>fe,K6:()=>C,K9:()=>We,O8:()=>ye,fL:()=>Le});/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const _=!1;function F(Ve){typeof Ve=="object"?Ve.dispose():Ve()}function fe(Ve){for(let ge=Ve.length;ge>0;--ge)F(Ve[ge-1])}function C(Ve,ge,me,Ie){return Ve.addEventListener(ge,me,Ie),()=>Ve.removeEventListener(ge,me,Ie)}class ye{constructor(){this.refCount=1}addRef(){return++this.refCount,this}dispose(){_&&(this.disposedStacks=this.disposedStacks||[]).push(new Error().stack),--this.refCount===0&&this.refCountReachedZero()}refCountReachedZero(){this.disposed();const{disposers:ge}=this;ge!==void 0&&(fe(ge),this.disposers=void 0),this.wasDisposed=!0}disposed(){}registerDisposer(ge){const{disposers:me}=this;return me==null?this.disposers=[ge]:me.push(ge),ge}unregisterDisposer(ge){const{disposers:me}=this;if(me!=null){const Ie=me.indexOf(ge);Ie!==-1&&me.splice(Ie,1)}return ge}registerEventListener(ge,me,Ie,tt){this.registerDisposer(C(ge,me,Ie,tt))}registerCancellable(ge){return this.registerDisposer(()=>{ge.cancel()}),ge}}class Le extends ye{constructor(ge){super(),this.value=ge}}function We(Ve){return()=>{if(Ve!==void 0){const ge=Ve;Ve=void 0,F(ge)}}}},3038:(se,Ee,G)=>{G.d(Ee,{I1:()=>Vn,Jh:()=>He,Oi:()=>Dt,PC:()=>qe,Qi:()=>ii,T2:()=>me,T_:()=>te,Yu:()=>C,Zc:()=>We,_A:()=>U,_S:()=>ee,_q:()=>T,bS:()=>cs,eR:()=>F,ln:()=>fe,nL:()=>q,p9:()=>ge,pB:()=>_,qp:()=>ve,r3:()=>Ve,sJ:()=>Qt,uD:()=>J,vs:()=>B,w0:()=>Le,xK:()=>ze,yb:()=>tt});var _=G(7684),F=G(329),fe=G(4796),C=G(2221),ye=G(4037),Le=G(1409),We=G(842);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Ve=_.create(),ge=["x","y","z"],me=[F.fromValues(1,0,0),F.fromValues(0,1,0),F.fromValues(0,0,1)],Ie=F.fromValues(0,0,0),tt=fe.fromValues(0,0,0,0),Dt=F.fromValues(1,1,1),Ge=F.fromValues(1/0,1/0,1/0),It=C.create();function ze(W){return W[0]*W[1]*W[2]}function Be(W){return W[0]*W[1]*W[2]*W[3]}function q(W){return`${W[0]},${W[1]},${W[2]}`}function ne(W,K){const ue=K[0],P=K[1],he=K[2],re=K[3];W[0]=re,W[1]=he,W[2]=-P,W[3]=-ue}function R(W,K){const ue=K[0],P=K[1],he=K[2],re=K[3];W[0]=-he,W[1]=re,W[2]=ue,W[3]=-P}function ae(W,K){const ue=K[0],P=K[1],he=K[2],re=K[3];W[0]=P,W[1]=-ue,W[2]=re,W[3]=-he}function B(W,K,ue){const P=K[0],he=K[1],re=K[2];return W[0]=ue[0]*P+ue[4]*he+ue[8]*re,W[1]=ue[1]*P+ue[5]*he+ue[9]*re,W[2]=ue[2]*P+ue[6]*he+ue[10]*re,W}function J(W,K,ue){const P=K[0],he=K[1],re=K[2];return W[0]=ue[0]*P+ue[1]*he+ue[2]*re,W[1]=ue[4]*P+ue[5]*he+ue[6]*re,W[2]=ue[8]*P+ue[9]*he+ue[10]*re,W}function $(W,K,ue,P,he){const re=W;return W[0]=P[0],W[1]=P[1],W[2]=P[2]*he,mat4.fromRotationTranslationScale(W,ue,K,re)}function M(W,K,ue){const P=ue.length;let he=0;for(let de=0;de-rt+Bn||ht<-rt-Bn)return!1}return!0}function qe(W,K,ue,P=!1){const he=ue.length,re=[],de=P?1:K+1,Pe=P?K+1:1;for(let Ze=0;Ze>>1&1)-1,f[2]=2*(ue>>>2&1)-1,F.transformMat4(f,f,W);for(let P=0;P<3;++P){const he=f[P];K[P]=Math.min(K[P],he),K[P+3]=Math.max(K[P+3],he)}}}},8626:()=>{if(typeof NEUROGLANCER_GOOGLE_TAG_MANAGER<"u"){const se="dataLayer",Ee=NEUROGLANCER_GOOGLE_TAG_MANAGER;window[se]=window[se]||[],window[se].push({"gtm.start":new Date().getTime(),event:"gtm.js"});const G=document.createElement("script");G.async=!0,G.src=`https://www.googletagmanager.com/gtm.js?id=${Ee}`,document.head.appendChild(G)}},9808:(se,Ee,G)=>{G.d(Ee,{Bk:()=>Ie,Dl:()=>Ge,El:()=>It,JZ:()=>We,Rc:()=>ge,cj:()=>me,j$:()=>fe,vd:()=>Ve});var _=G(4509),F=G(8796);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class fe extends Error{constructor(Be,q,ne,R){let ae=`Fetching ${JSON.stringify(Be)} resulted in HTTP error ${q}`;ne&&(ae+=`: ${ne}`),ae+=".",super(ae),this.name="HttpError",this.message=ae,this.url=Be,this.status=q,this.statusText=ne,R&&(this.response=R)}static fromResponse(Be){return new fe(Be.url,Be.status,Be.statusText,Be)}static fromRequestError(Be,q){if(q instanceof TypeError){let ne;return typeof Be=="string"?ne=Be:ne=Be.url,new fe(ne,0,"Network or CORS error")}return q}}const C=32,ye=500,Le=1e4;function We(ze){return Math.min(2**ze*ye,Le/2)*(1+Math.random())}async function Ve(ze,Be){for(let q=0;;){if(Be?.signal?.aborted)throw _.wS;let ne;try{ne=await fetch(ze,Be)}catch(R){throw fe.fromRequestError(ze,R)}if(!ne.ok){const{status:R}=ne;if((R===429||R===503||R===504)&&++q!==C){await new Promise(ae=>setTimeout(ae,We(q-1)));continue}throw fe.fromResponse(ne)}return ne}}function ge(ze){return ze.arrayBuffer()}function me(ze){return ze.json()}async function Ie(ze,Be,q,ne=_.fx){if(ne===_.fx){const B=await Ve(ze,Be);return await q(B)}const R=new AbortController,ae=ne.add(()=>R.abort());try{const B=await Ve(ze,{...Be,signal:R.signal});return await q(B)}finally{ae()}}const tt=new F.R;function Dt(ze,Be){let q;return typeof Be=="number"?q=`${Be-1}`:(Uint64.decrement(tt,Be),q=tt.toString()),{Range:`bytes=${ze}-${q}`}}function Ge(ze){const Be=/^([^:/]+):\/\/([^/]+)((?:\/.*)?)$/,q=ze.match(Be);if(q===null)throw new Error(`Invalid URL: ${JSON.stringify(ze)}`);return{protocol:q[1],host:q[2],path:q[3]}}function It(ze){return ze instanceof fe?ze.status===0||ze.status===403||ze.status===404:!1}},7900:(se,Ee,G)=>{G.d(Ee,{$v:()=>ve,B8:()=>Qt,DW:()=>We,J6:()=>te,JB:()=>me,JY:()=>Le,MM:()=>he,Mo:()=>ye,Rf:()=>Xe,Sf:()=>T,VH:()=>Bn,Vr:()=>Ve,We:()=>Vn,Xu:()=>qe,ZD:()=>Bt,Zu:()=>Lt,Zw:()=>C,_D:()=>F,aO:()=>ds,bL:()=>Pe,bX:()=>He,by:()=>rt,cQ:()=>P,f4:()=>st,gG:()=>ht,j3:()=>ii,pf:()=>qt,qi:()=>Ii,si:()=>Kt,sl:()=>et,uS:()=>K,uz:()=>Ze,vS:()=>re,vp:()=>ge,xU:()=>de,z$:()=>cs,zB:()=>W,zo:()=>fe,zr:()=>f});var _=G(3038);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function F(A){const H=typeof A;if(H==="number"||H==="string"){const ie=parseFloat(""+A);if(!Number.isNaN(ie))return ie}throw new Error(`Expected floating-point number, but received: ${JSON.stringify(A)}.`)}function fe(A){const H=F(A);if(Number.isFinite(H))return H;throw new Error(`Expected finite floating-point number, but received: ${H}.`)}function C(A){const H=F(A);if(Number.isFinite(H)&&H>=0)return H;throw new Error(`Expected finite non-negative floating-point number, but received: ${H}.`)}function ye(A){const H=fe(A);if(H>0)return H;throw new Error(`Expected positive finite floating-point number, but received: ${H}.`)}function Le(A,H){return ie=>{const le=F(ie);if(le>=A&&le<=H)return le;throw new Error(`Expected floating-point number in range [${A}, ${H}], but received: ${le}.`)}}function We(A,H,ie=F){Xe(H),A[0]=A[1]=A[2]=0;for(const le of Object.keys(H))switch(le){case"x":A[0]=ie(H[le]);break;case"y":A[1]=ie(H[le]);break;case"z":A[2]=ie(H[le]);break;default:throw new Error(`Expected object to have keys ['x', 'y', 'z'], but received: ${JSON.stringify(H)}.`)}return A}function Ve(A,H){const ie=A.length;if(!Array.isArray(H)||H.length!==ie)throw new Error("Incompatible sizes");for(let le=0;leH==='"'?"'":'"')}function tt(A){return Ie(JSON.stringify(Ie(A)))}const Dt="_";function Ge(A){if(typeof A=="object"){if(A===null)return"null";const H=A.toJSON;if(typeof H=="function")return Ge(H.call(A));if(Array.isArray(A)){let Te="[";const ot=A.length;let ut=0;if(ut=2&&A.charAt(0)===H&&A.charAt(A.length-1)===H){let Ce=A.substr(1,A.length-2),Te=ie;for(;Ce.length>0;){const ot=Ce.match(le);if(ot===null){Te+=Ce;break}Te+=ot[1],ot[2]===ie?(Te+="\\",Te+=ie):Te+=H,Ce=Ce.substr(ot.index+ot[0].length)}return Te+=ie,Te}return A}function B(A){return ae(A,"'",'"',ne)}function J(A,H,ie){const le=/[&_,]/g;let Ce,Te,ot;ie==='"'?(Ce="'",Te=ne,ot=Be):(Ce='"',Te=R,ot=q);let ut="";for(;A.length>0;){const j=A.match(ot);let Li,Re;if(j===null)Li=A,A="",Re="";else{Li=A.substr(0,j.index),A=A.substr(j.index+j[0].length);const Xt=j[1];Xt!==void 0?Re=ae(Xt,Ce,ie,Te):Re=j[2]}ut+=Li.replace(le,H),ut+=Re}return ut}function $(A){return J(A,",",'"')}function M(A){return J(A,"_","'")}function T(A){return JSON.parse($(A))}function U(A){let H="";for(;A.length>0;){const ie=A.match(Be);let le,Ce;if(ie===null)le=A,A="",Ce="";else{le=A.substr(0,ie.index),A=A.substr(ie.index+ie[0].length);const Te=ie[1];Te!==void 0?Ce=B(Te):Ce=ie[2]}H+=le.replace(/\(/g,"[").replace(/\)/g,"]").replace("True","true").replace("False","false").replace(/,\s*([}\]])/g,"$1"),H+=Ce}return H}function ee(A){return JSON.parse(U(A))}function te(A,H){if(!Array.isArray(A))throw new Error(`Expected array, but received: ${JSON.stringify(A)}.`);if(H!==void 0&&A.length!==H)throw new Error(`Expected array of length ${H}, but received: ${JSON.stringify(A)}.`);return A}function ve(A,H){if(!Array.isArray(A))throw new Error(`Expected array, but received: ${JSON.stringify(A)}.`);return A.map(H)}function qe(A,H,ie){const le=A.length;if(!Array.isArray(H)||H.length!==le)throw new Error(`Expected length ${le} array, but received: ${JSON.stringify(H)}.`);for(let Ce=0;CeCe===void 0?le:ie(Ce))}function re(A,H){Xe(A);const ie=new Map;for(const le of Object.keys(A))try{ie.set(le,H(A[le]))}catch(Ce){throw new Error(`Error parsing value associated with key ${JSON.stringify(le)}: ${Ce.message}`)}return ie}function de(A){if(typeof A!="number"||!Number.isFinite(A)||A<0||A>1)throw new Error(`Expected floating point number in [0,1], but received: ${JSON.stringify(A)}.`);return A}function Pe(A){if(A==="")return{};if(A.startsWith("{"))return T(A);const H={},ie=A.split(/[&;]/);for(const le of ie){const Ce=le.match(/^([^=&;]+)=([^&;]*)$/);if(Ce===null)throw new Error(`Invalid query string part: ${JSON.stringify(le)}.`);H[Ce[1]]=decodeURIComponent(Ce[2])}return H}function Ze(A){if(A===void 0)return"";const H=Object.keys(A);return H.length===0?"":H.some(ie=>typeof A[ie]!="string")?JSON.stringify(A):H.map(ie=>`${encodeURIComponent(ie)}=${encodeURIComponent(A[ie])}`).join("&")}function et(A,H,ie=/^[a-zA-Z]/){if(typeof A=="string"&&A.match(ie)!==null){const le=A.toUpperCase();if(Object.prototype.hasOwnProperty.call(H,le))return H[le]}throw new Error(`Invalid enum value: ${JSON.stringify(A)}.`)}function st(A){return qe(_.eR.create(),A,fe)}function rt(A){return qe(_.eR.create(),A,ye)}function ht(A){return qe(_.eR.create(),A,Vn)}function Kt(A){if(!Array.isArray(A))throw new Error(`Expected array, received: ${JSON.stringify(A)}.`);for(const H of A)if(typeof H!="string")throw new Error(`Expected string, received: ${JSON.stringify(H)}.`);return A}function Bn(A){if(!Array.isArray(A))throw new Error(`Expected array, received: ${JSON.stringify(A)}.`);for(const H of A)if(!Number.isInteger(H))throw new Error(`Expected integer, received: ${JSON.stringify(H)}.`);return A}function qt(A){if(!Array.isArray(A))throw new Error(`Expected array, received: ${JSON.stringify(A)}.`);for(const H of A)F(H);return A}function ds(A){if(typeof A!="boolean")throw new Error(`Expected boolean, received: ${JSON.stringify(A)}`);return A}function Lt(A){for(const H in A)return A}function Ii(A,H){if(A!==H)throw new Error(`Expected ${JSON.stringify(H)}, but received: ${JSON.stringify(A)}`);return H}function Bt(A,H){if(A===void 0){const ie=new Array(H);return ie.fill(null),ie}return qe(new Array(H),A,ie=>{if(ie!==null&&typeof ie!="string")throw new Error(`Expected string or null, but received: ${JSON.stringify(name)}`);return ie})}},147:(se,Ee,G)=>{G.d(Ee,{Aw:()=>Ve,C:()=>We,DA:()=>fe,DI:()=>Ie,LC:()=>tt,Lk:()=>Le,_U:()=>It,ay:()=>ze,lw:()=>_,nx:()=>C,u6:()=>ye,vo:()=>Ge});/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function _(q,ne,R,ae,B,J,$,M,T){for(let U=0;U<$;++U)for(let ee=0;eeU&&(U=te,$=ee)}}if(B!==$){ae*=-1;for(let U=0;U{G.d(Ee,{$$:()=>C,HN:()=>_,IY:()=>fe});/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class _{constructor(){this.handlers=new Set,this.count=0;const Le=this;this.dispatch=function(){++Le.count,Le.handlers.forEach(We=>{We.apply(this,arguments)})}}add(Le){return this.handlers.add(Le),()=>this.remove(Le)}remove(Le){return this.handlers.delete(Le)}dispose(){this.handlers=void 0}}function F(ye,...Le){ye();for(let We=0,Ve=Le.length;We{for(let We=0,Ve=Le.length;We{}},remove(ye){return!1}}},2974:(se,Ee,G)=>{se.exports=G.p+"bossauth.html"},3956:(se,Ee,G)=>{se.exports=G.p+"google_oauth2_redirect.html"},4320:(se,Ee,G)=>{var _=G(3206),F=G(4037),fe=G(8103),C=G(3038);/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function ye(i){return("0"+i.toString(16)).slice(-2)}function Le(i){return Array.prototype.map.call(i,ye).join("")}function We(i){if(!/^(?:[0-9a-fA-F]{2})*$/.test(i))throw new Error("Invalid hex-encoded string");const e=i.length/2,t=new Uint8Array(e);for(let n=0;n>>0)+Math.min(255,Math.max(0,Math.round(i[e-1-n]*255)));return t}function tt(i){return C.eR.fromValues((i>>>0&255)/255,(i>>>8&255)/255,(i>>>16&255)/255)}function Dt(i){return C.ln.fromValues((i>>>0&255)/255,(i>>>8&255)/255,(i>>>16&255)/255,(i>>>24&255)/255)}function Ge(i){if(i[3]===void 0||i[3]===1){let t="#";for(let n=0;n<3;++n)t+=ye(Math.min(255,Math.max(0,Math.round(i[n]*255))));return t}let e="rgba(";for(let t=0;t<3;++t)t!==0&&(e+=", "),e+=Math.min(255,Math.max(0,Math.round(i[t]*255)));return e+=`, ${(0,fe.K)(i[3])})`,e}function It(i){return i<=.03928?i/12.92:((i+.055)/1.055)**2.4}function ze(i){const[e,t,n]=i;return .2126*It(e)+.7152*It(t)+.0722*It(n)}function Be(i){return ze(i)<=.179}class q extends _.B0{constructor(e){super(C.eR.clone(e)),this.defaultValue=e}toString(){return Ge(this.value)}toJSON(){if(!C.eR.equals(this.value,this.defaultValue))return Ge(this.value)}reset(){this.value=C.eR.clone(this.defaultValue)}restoreState(e){if(e===void 0){this.reset();return}const{value:t}=this,n=me(e);C.eR.equals(t,n)||(this.value=n)}}class ne extends _.B0{constructor(){super(void 0)}toJSON(){const{value:e}=this;if(e!==void 0)return Ge(e)}reset(){this.value=void 0}restoreState(e){if(e===void 0){this.reset();return}const{value:t}=this,n=me(e);(t===void 0||!C.eR.equals(t,n))&&(this.value=n)}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var R=(i=>(i[i.UINT8=0]="UINT8",i[i.INT8=1]="INT8",i[i.UINT16=2]="UINT16",i[i.INT16=3]="INT16",i[i.UINT32=4]="UINT32",i[i.INT32=5]="INT32",i[i.UINT64=6]="UINT64",i[i.FLOAT32=7]="FLOAT32",i))(R||{});const ae={0:!1,1:!0,2:!1,3:!0,4:!1,5:!0,6:!1,7:void 0},B={0:1,1:1,2:2,3:2,4:4,5:4,6:8,7:4},J={0:Uint8Array,1:Int8Array,2:Uint16Array,3:Int16Array,4:Uint32Array,5:Int32Array,6:Uint32Array,7:Float32Array},$={0:1,1:1,2:1,3:1,4:1,5:1,6:2,7:1};function M(i,e,t=0,n=e.byteLength){const s=B[i],r=$[i];return new J[i](e,t,n/s*r)}var T=G(2596);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var U=(i=>(i[i.LITTLE=0]="LITTLE",i[i.BIG=1]="BIG",i))(U||{});function ee(){const i=Uint16Array.of(4386);return new Uint8Array(i.buffer)[0]===17?1:0}const te=ee();function ve(i){const e=new Uint8Array(i.buffer,i.byteOffset,i.byteLength);for(let t=0,n=e.length;ti==i>0?K[t]===4294967295?(K[t]=0,K[n]+=1):K[t]+=1:K[t]===0?(K[t]=4294967295,K[n]-=1):K[t]-=1,W[0]}var P=G(8796);/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const he={[R.UINT8]:[0,255],[R.INT8]:[-128,127],[R.UINT16]:[0,65535],[R.INT16]:[-32768,32767],[R.UINT32]:[0,4294967295],[R.INT32]:[-2147483648,2147483647],[R.UINT64]:[P.R.ZERO,new P.R(4294967295,4294967295)],[R.FLOAT32]:[0,1]};function re(i,e){if(typeof e=="number"){const o=i[0],a=i[1];return(e-o)/(a-o)}const t=i[0],n=i[1];let s;P.R.compare(e,t)<0?s=-P.R.subtract(ht,t,e).toNumber():s=P.R.subtract(ht,e,t).toNumber();let r=P.R.absDifference(ht,n,t).toNumber();return P.R.compare(t,n)>0&&(r*=-1),s/r}function de(i,e,t){if(typeof i[0]=="number"){const a=i[0],l=i[1];let c=a*(1-t)+l*t;if(e!==R.FLOAT32){const d=he[e];c=Math.round(c),c=Math.max(d[0],c),c=Math.min(d[1],c)}return c}let n=i[0],s=i[1];P.R.compare(n,s)>0&&([n,s]=[s,n],t=1-t);const r=P.R.subtract(ht,s,n).toNumber(),o=new P.R;return t<=0?(ht.setFromNumber(r*-t),P.R.subtract(o,n,P.R.min(ht,n))):t>=1?(ht.setFromNumber(r*(t-1)),P.R.add(o,s,ht),P.R.less(o,s)&&(o.low=o.high=4294967295)):(ht.setFromNumber(r*t),P.R.add(o,n,ht),P.R.less(o,n)&&(o.low=o.high=4294967295)),o}function Pe(i,e){return typeof e=="number"?Math.min(Math.max(i[0],e),i[1]):P.R.min(P.R.max(i[0],e),i[1])}function Ze(i,e){return[Pe(i,e[0]),Pe(i,e[1])]}function et(i){if(rt(i[0],i[1])<=0)return i;throw new Error(`Invalid interval: [${i[0]}, ${i[1]}]`)}function st(i){return rt(i[0],i[1])<=0?i:[i[1],i[0]]}function rt(i,e){return typeof i=="number"?i-e:P.R.compare(i,e)}const ht=new P.R,Kt=new P.R;function Bn(i,e){return typeof e=="number"?Math.abs(e-i[0])s[1])throw new Error(`Invalid ${R[i].toLowerCase()} value: ${JSON.stringify(t)}`);return n}}}function ds(i){if(typeof i=="number")return i;if(typeof i=="string"){const e=new P.R,t=Number(i);if(e.tryParseString(i))return t.toString()===e.toString()?t:e;if(!Number.isFinite(t))throw new Error(`Invalid value: ${JSON.stringify(i)}`);return t}throw new Error(`Invalid value: ${JSON.stringify(i)}`)}function Lt(i,e){return(0,f.Xu)(new Array(2),i,t=>qt(e,t))}function Ii(i){return(0,f.Xu)(new Array(2),i,e=>ds(e))}function Bt(i,e,t){return i===R.UINT64?P.R.equal(e[0],t[0])&&P.R.equal(e[1],t[1]):e[0]===t[0]&&e[1]===t[1]}function A(i,e,t=he[e]){if(!Bt(e,i,t))return e===R.UINT64?[i[0].toString(),i[1].toString()]:i}function H(i,e,t){switch(i){case R.FLOAT32:return ue(e,t*(1/0));case R.UINT64:{const n=e;return t===-1?n.low===0&&n.high===0?n:P.R.decrement(new P.R,n):n.low===4294967295&&n.high===4294967295?n:P.R.increment(new P.R,n)}default:{const n=he[i];return Math.max(n[0],Math.min(n[1],e+t))}}}function ie(i,e){switch(i){case R.FLOAT32:return 0;case R.UINT64:return .5/P.R.absDifference(ht,e[0],e[1]).toNumber();default:return .5/Math.abs(e[0]-e[1])}}function le(i,e){switch(i){case R.FLOAT32:return 1;case R.UINT64:{const t=P.R.absDifference(ht,e[0],e[1]).toNumber();return t/(t+1)}default:{const t=Math.abs(e[0]-e[1]);return t/(t+1)}}}function Ce(i,e){if(i===void 0)return he[e];let[t,n]=i;if(e===R.UINT64)return typeof t=="number"&&(t=P.R.fromNumber(t)),typeof n=="number"&&(n=P.R.fromNumber(n)),[t,n];if(typeof t!="number"&&(t=t.toNumber()),typeof n!="number"&&(n=n.toNumber()),e!==R.FLOAT32){t=Math.round(t),n=Math.round(n);const s=he[e];Number.isFinite(t)?t=Math.min(Math.max(s[0],t),s[1]):t=s[0],Number.isFinite(n)?n=Math.min(Math.max(s[0],n),s[1]):n=s[1]}return[t,n]}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Te(i=128){const e=Math.ceil(i/32),t=new Uint32Array(e);crypto.getRandomValues(t);let n="";for(let s=0;s(i[i.POINT=0]="POINT",i[i.LINE=1]="LINE",i[i.AXIS_ALIGNED_BOUNDING_BOX=2]="AXIS_ALIGNED_BOUNDING_BOX",i[i.ELLIPSOID=3]="ELLIPSOID",i))(Re||{});const Xt=[0,1,2,3],kl={float32:R.FLOAT32,uint32:R.UINT32,int32:R.INT32,uint16:R.UINT16,int16:R.INT16,uint8:R.UINT8,int8:R.INT8,rgb:void 0,rgba:void 0};function jb(i){return i.type!=="rgb"&&i.type!=="rgba"}function us(i){return i.type==="uint8"&&i.tag!==void 0}const si={rgb:{serializedBytes(){return 3},alignment(){return 1},serializeCode(i,e){return`dv.setUint16(${e}, ${i}, true);dv.setUint8(${e} + 2, ${i} >>> 16);`},deserializeCode(i,e){return`${i} = dv.getUint16(${e}, true) | (dv.getUint8(${e} + 2) << 16);`},deserializeJson(i){return Ie(me(i))},serializeJson(i){return Ge(tt(i))}},rgba:{serializedBytes(){return 4},alignment(){return 1},serializeCode(i,e){return`dv.setUint32(${e}, ${i}, true);`},deserializeCode(i,e){return`${i} = dv.getUint32(${e}, true);`},deserializeJson(i){return Ie(ge(i))},serializeJson(i){return Ge(Dt(i))}},float32:{serializedBytes(){return 4},alignment(){return 4},serializeCode(i,e){return`dv.setFloat32(${e}, ${i}, isLittleEndian);`},deserializeCode(i,e){return`${i} = dv.getFloat32(${e}, isLittleEndian);`},deserializeJson(i){return(0,f._D)(i)},serializeJson(i){return i}},uint32:{serializedBytes(){return 4},alignment(){return 4},serializeCode(i,e){return`dv.setUint32(${e}, ${i}, isLittleEndian);`},deserializeCode(i,e){return`${i} = dv.getUint32(${e}, isLittleEndian);`},deserializeJson(i){return(0,f.bX)(i)},serializeJson(i){return i}},int32:{serializedBytes(){return 4},alignment(){return 4},serializeCode(i,e){return`dv.setInt32(${e}, ${i}, isLittleEndian);`},deserializeCode(i,e){return`${i} = dv.getInt32(${e}, isLittleEndian);`},deserializeJson(i){return(0,f.bX)(i)},serializeJson(i){return i}},uint16:{serializedBytes(){return 2},alignment(){return 2},serializeCode(i,e){return`dv.setUint16(${e}, ${i}, isLittleEndian);`},deserializeCode(i,e){return`${i} = dv.getUint16(${e}, isLittleEndian);`},deserializeJson(i){return(0,f.bX)(i)},serializeJson(i){return i}},int16:{serializedBytes(){return 2},alignment(){return 2},serializeCode(i,e){return`dv.setInt16(${e}, ${i}, isLittleEndian);`},deserializeCode(i,e){return`${i} = dv.getInt16(${e}, isLittleEndian);`},deserializeJson(i){return(0,f.bX)(i)},serializeJson(i){return i}},uint8:{serializedBytes(){return 1},alignment(){return 1},serializeCode(i,e){return`dv.setUint8(${e}, ${i});`},deserializeCode(i,e){return`${i} = dv.getUint8(${e});`},deserializeJson(i){return(0,f.bX)(i)},serializeJson(i){return i}},int8:{serializedBytes(){return 2},alignment(){return 1},serializeCode(i,e){return`dv.setInt8(${e}, ${i});`},deserializeCode(i,e){return`${i} = dv.getInt8(${e});`},deserializeJson(i){return(0,f.bX)(i)},serializeJson(i){return i}}},Yb=255;function xh(i,e,t){let n=0;const s=t.length,r=new Array(s),o=[];for(let h=0;hsi[t[h].type].alignment(i);r.sort((h,p)=>a(p)-a(h));let l=0;const c=new Array(s);let d=e;const u=()=>{d+=(4-d%4)%4,n+=d,o[l]=d,d=0,++l};for(let h=0;h{},this.propertyGroupBytes=[t];return}const{serializedBytes:s,offsets:r,propertyGroupBytes:o}=xh(e,t,n);this.propertyGroupBytes=o;let a="let groupOffset0 = offset;";for(let u=1;usi[t].deserializeJson(l),0);let r,o,a;switch(t){case"rgb":case"rgba":break;default:{const l=R[t.toUpperCase()];r=(0,f.MM)(i,"enum_values",c=>(0,f.$v)(c,d=>qt(l,d))),r!==void 0&&(o=(0,f.cQ)(i,"enum_labels",c=>(0,f.Xu)(new Array(r.length),c,f.zr))),a=(0,f.MM)(i,"tag",f.zr)}}return{type:t,identifier:e,description:n,default:s,enumValues:r,enumLabels:o,tag:a}}function eC(i){const e=i.default,t=jb(i),n=t?i.tag:void 0,s=t?i.enumValues:void 0,r=t?i.enumLabels:void 0;return{id:i.identifier,description:i.description,type:i.type,tag:n,enum_values:s,enum_labels:r,default:e===0?void 0:si[i.type].serializeJson(e)}}function tC(i){if(!(i===void 0||i.length===0))return i.map(eC)}function Dh(i){if(i===void 0)return[];const e=(0,f.$v)(i,Zb);return Xb(e),e}function Al(i,e,t,n,s){for(let r=0;r(0,f.Xu)(new Float32Array(t),n,f.zo)),i.pointB=(0,f.cQ)(e,"pointB",n=>(0,f.Xu)(new Float32Array(t),n,f.zo))},serializedBytes(i){return 2*4*i},serialize(i,e,t,n,s){Ml(i,e,t,n,s.pointA,s.pointB)},deserialize:(i,e,t,n,s)=>{const r=new Float32Array(n),o=new Float32Array(n);return Ol(i,e,t,n,r,o),{type:1,pointA:r,pointB:o,id:s,properties:[]}},visitGeometry(i,e){e(i.pointA,!1),e(i.pointB,!1)}},0:{icon:"\u26AC",description:"Point",toJSON:i=>({point:Array.from(i.point)}),restoreState:(i,e,t)=>{i.point=(0,f.cQ)(e,"point",n=>(0,f.Xu)(new Float32Array(t),n,f.zo))},serializedBytes:i=>i*4,serialize:(i,e,t,n,s)=>{Al(i,e,t,n,s.point)},deserialize:(i,e,t,n,s)=>{const r=new Float32Array(n);return Nl(i,e,t,n,r),{type:0,point:r,id:s,properties:[]}},visitGeometry(i,e){e(i.point,!1)}},2:{icon:"\u2751",description:"Bounding Box",toJSON:i=>({pointA:Array.from(i.pointA),pointB:Array.from(i.pointB)}),restoreState:(i,e,t)=>{i.pointA=(0,f.cQ)(e,"pointA",n=>(0,f.Xu)(new Float32Array(t),n,f.zo)),i.pointB=(0,f.cQ)(e,"pointB",n=>(0,f.Xu)(new Float32Array(t),n,f.zo))},serializedBytes:i=>2*4*i,serialize(i,e,t,n,s){Ml(i,e,t,n,s.pointA,s.pointB)},deserialize:(i,e,t,n,s)=>{const r=new Float32Array(n),o=new Float32Array(n);return Ol(i,e,t,n,r,o),{type:2,pointA:r,pointB:o,id:s,properties:[]}},visitGeometry(i,e){e(i.pointA,!1),e(i.pointB,!1)}},3:{icon:"\u25CE",description:"Ellipsoid",toJSON:i=>({center:Array.from(i.center),radii:Array.from(i.radii)}),restoreState:(i,e,t)=>{i.center=(0,f.cQ)(e,"center",n=>(0,f.Xu)(new Float32Array(t),n,f.zo)),i.radii=(0,f.cQ)(e,"radii",n=>(0,f.Xu)(new Float32Array(t),n,f.Zw))},serializedBytes:i=>2*4*i,serialize(i,e,t,n,s){Ml(i,e,t,n,s.center,s.radii)},deserialize:(i,e,t,n,s)=>{const r=new Float32Array(n),o=new Float32Array(n);return Ol(i,e,t,n,r,o),{type:3,center:r,radii:o,id:s,properties:[]}},visitGeometry(i,e){e(i.center,!1),e(i.radii,!0)}}};function _l(i,e){const t=Ft[i.type].toJSON(i,e.rank);t.type=Re[i.type].toLowerCase(),t.id=i.id,t.description=i.description||void 0;const{relatedSegments:n}=i;n?.some(r=>r.length!==0)&&(t.segments=n.map(r=>r.map(o=>o.toString())));const s=e.properties.value;return s.length!==0&&(t.props=i.properties.map((r,o)=>si[s[o].type].serializeJson(r))),t}function nC(i,e,t=!1){(0,f.Rf)(i);const n=(0,f.cQ)(i,"type",l=>(0,f.sl)(l,Re)),s=(0,f.cQ)(i,"id",t?f.z$:f.zr)||Vl(),r=(0,f.cQ)(i,"segments",l=>{if(l===void 0)return e.relationships.map(()=>[]);const c=(0,f.J6)(l);return c.length===0?e.relationships.map(()=>[]):e.relationships.length===1&&!Array.isArray(c[0])?[(0,f.$v)(c,d=>P.R.parseString(d))]:(0,f.$v)((0,f.J6)(l,e.relationships.length),d=>(0,f.$v)(d,u=>P.R.parseString(u)))}),o=(0,f.cQ)(i,"props",l=>{const c=e.properties.value;return l===void 0?c.map(d=>d.default):(0,f.$v)((0,f.J6)(l,c.length),(d,u)=>si[c[u].type].deserializeJson(d))}),a={id:s,description:(0,f.cQ)(i,"description",f.z$),relatedSegments:r,properties:o,type:n};return Ft[n].restoreState(a,i,e.rank),a}class hs extends T.O8{constructor(e,t=[],n=new _.B0([])){super(),this.relationships=t,this.properties=n,this.annotationMap=new Map,this.changed=new j.IY,this.readonly=!1,this.childAdded=new j.HN,this.childUpdated=new j.HN,this.childCommitted=new j.HN,this.childDeleted=new j.HN,this.pending=new Set,this.references=new Map,this.rank_=e,this.annotationPropertySerializers=Pl(e,n.value)}get rank(){return this.rank_}hasNonSerializedProperties(){return!0}add(e,t=!0){if(this.ensureUpdated(),!e.id)e.id=Vl();else if(this.annotationMap.has(e.id))throw new Error(`Annotation id already exists: ${JSON.stringify(e.id)}.`);return this.annotationMap.set(e.id,e),t||this.pending.add(e.id),this.changed.dispatch(),this.childAdded.dispatch(e),t&&this.childCommitted.dispatch(e.id),this.getReference(e.id)}commit(e){this.ensureUpdated();const t=e.id;this.pending.delete(t),this.changed.dispatch(),this.childCommitted.dispatch(t)}update(e,t){if(this.ensureUpdated(),e.value===null)throw new Error("Annotation already deleted.");e.value=t,this.annotationMap.set(t.id,t),e.changed.dispatch(),this.changed.dispatch(),this.childUpdated.dispatch(t)}[Symbol.iterator](){return this.ensureUpdated(),this.annotationMap.values()}get(e){return this.ensureUpdated(),this.annotationMap.get(e)}delete(e){e.value!==null&&(e.value=null,this.annotationMap.delete(e.id),this.pending.delete(e.id),e.changed.dispatch(),this.changed.dispatch(),this.childDeleted.dispatch(e.id))}getReference(e){let t=this.references.get(e);return t!==void 0?t.addRef():(t=new Li(e),t.value=this.annotationMap.get(e)||null,this.references.set(e,t),t.registerDisposer(()=>{this.references.delete(e)}),t)}ensureUpdated(){}toJSON(){this.ensureUpdated();const e=[],{pending:t}=this;for(const n of this)t.has(n.id)||e.push(_l(n,this));return e}clear(){this.annotationMap.clear(),this.pending.clear(),this.changed.dispatch()}restoreState(e){this.ensureUpdated();const{annotationMap:t}=this;t.clear(),this.pending.clear(),e!==void 0&&(0,f.$v)(e,n=>{const s=nC(n,this);t.set(s.id,s)});for(const n of this.references.values()){const{id:s}=n,r=t.get(s);n.value=r||null,n.changed.dispatch()}this.changed.dispatch()}reset(){this.clear()}}class Ih extends hs{constructor(e,t=new _.B0([]),n){super(e.value.sourceRank,n,t),this.watchableTransform=e,this.properties=t,this.getTagProperties=()=>{const{properties:s}=this;return s.value.filter(us)},this.curCoordinateTransform=e.value,this.registerDisposer(e.changed.add(()=>this.ensureUpdated())),this.registerDisposer(t.changed.add(()=>{this.updateAnnotationPropertySerializers(),this.changed.dispatch()}))}get rank(){return this.ensureUpdated(),this.rank_}updateAnnotationPropertySerializers(){this.annotationPropertySerializers=Pl(this.rank_,this.properties.value)}addProperty(e){this.properties.value.push(e);for(const t of this)t.properties.push(e.default);this.properties.changed.dispatch()}removeProperty(e){const t=this.properties.value.findIndex(n=>n.identifier===e);this.properties.value.splice(t,1);for(const n of this)n.properties.splice(t,1);this.properties.changed.dispatch()}ensureUpdated(){const e=this.watchableTransform.value,{curCoordinateTransform:t}=this;if(e===t)return;this.curCoordinateTransform=e;const n=e.sourceRank,s=t.sourceRank;if(s===n&&(t.inputSpace===e.inputSpace||(0,F.r1)(t.inputSpace.ids.slice(0,n),e.inputSpace.ids.slice(0,n))))return;const{ids:r}=e.inputSpace,o=t.inputSpace.ids,a=[];for(let c=0;c=s&&(d=-1),a.push(d)}const l=c=>{const d=new Float32Array(n);for(let u=0;uS.id),r[c]=new Map(p.map((S,w)=>[S.id,w]));const g=Ft[c].serialize,v=n[c],y=d.propertyGroupBytes[0];for(let S=0,w=p.length;Snew P.R(r.low,r.high)))}return i}var De=G(147);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const lo=[{prefix:"Y",exponent:24,longPrefix:"yotta"},{prefix:"Z",exponent:21,longPrefix:"zetta"},{prefix:"E",exponent:18,longPrefix:"exa"},{prefix:"P",exponent:15,longPrefix:"peta"},{prefix:"T",exponent:12,longPrefix:"tera"},{prefix:"G",exponent:9,longPrefix:"giga"},{prefix:"M",exponent:6,longPrefix:"mega"},{prefix:"k",exponent:3,longPrefix:"kilo"},{prefix:"",exponent:0,longPrefix:""},{prefix:"m",exponent:-3,longPrefix:"milli"},{prefix:"\xB5",exponent:-6,longPrefix:"micro"},{prefix:"n",exponent:-9,longPrefix:"nano"},{prefix:"p",exponent:-12,longPrefix:"pico"},{prefix:"f",exponent:-15,longPrefix:"femto"},{prefix:"a",exponent:-18,longPrefix:"atto"},{prefix:"z",exponent:-21,longPrefix:"zepto"},{prefix:"y",exponent:-24,longPrefix:"yocto"}],Bl=[...lo,{prefix:"h",exponent:2,longPrefix:"hecto"},{prefix:"da",exponent:1,longPrefix:"deca"},{prefix:"d",exponent:-1,longPrefix:"deci"},{prefix:"c",exponent:-2,longPrefix:"centi"}],aC=[{prefix:"u",exponent:-6},...Bl],ir=new Map;ir.set("",{unit:"",exponent:0});const lC=new Map;for(const{prefix:i,exponent:e}of aC){lC.set(e,i);for(const t of["m","s","Hz","rad/s"])ir.set(`${i}${t}`,{unit:t,exponent:e})}function Rh(i){const e=Math.log10(i),t=lo.length,n=(0,F.lX)(0,t,s=>lo[s].exponent<=e);return lo[Math.min(n,t-1)]}function kh(i,e,t={}){const{precision:n=6,elide1:s=!0}=t;let r=i,o="";if(e!==""){const l=Rh(i);o=l.prefix,r=Fl(i,-l.exponent)}if(s&&r===1)return{scale:"",unit:e,prefix:o};let a;if(n!==0){r<1||r>=1e3?a=r.toPrecision(n):a=r.toFixed(n);const l=a.indexOf("e");let c,d;l!==-1?(c=a.substring(0,l),d=a.substring(l)):(c=a,d="");const u=c.match(/.*\.(?:[0-9]*[1-9])?(0+)$/);u!==null&&(c=c.substring(0,c.length-u[1].length),c.endsWith(".")&&(c=c.substring(0,c.length-1)),a=c+d)}else a=r.toString();return{scale:a,unit:e,prefix:o}}function Ri(i,e,t){const{scale:n,unit:s,prefix:r}=kh(i,e,t);return`${n}${r}${s}`}function sr(i){if(i==="")return{scale:1,unit:""};const e=i.match(/^((?:0|[1-9]\d*)(?:\.\d+)?(?:[eE][+-]?\d+)?)?([µa-zA-Z]+)?$/);if(e===null)return;const t=e[1];let n=t===void 0?1:Number(t);if(Number.isNaN(n))return;let s="";if(e[2]!==void 0){const r=ir.get(e[2]);if(r===void 0)return;s=r.unit,r.exponent>0?n*=10**r.exponent:n/=10**-r.exponent}if(!(n<=0||!Number.isFinite(n)))return{scale:n,unit:s}}function Ph(i){const e=ir.get(i);if(e===void 0)throw new Error(`Invalid unit: ${JSON.stringify(i)}`);return e}function Fl(i,e){return e>=0?i*10**e:i/10**-e}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function yV(i,e){const t=i.length;for(let n=0;nn-s),e=Array.from(i,n=>t.get(n)),{coordinates:i,labels:e}}function Nh(i){if(i.length===1)return i[0];const e=new Map;let t=!1;for(const r of i){r.explicit&&(t=!0);const{coordinates:o,labels:a}=r;for(let l=0,c=o.length;lr-o);const s=Array.from(n,r=>e.get(r));return{explicit:t,coordinates:n,labels:s}}function Oh(i){if(i=i.filter(e=>e!==void 0),i.length!==0)return Nh(i)}function mC(i,e){return(0,F.r1)(i.transform,e.transform)&&pC(i.box,e.box)}function co(i,e){return i.valid===e.valid&&i.rank===e.rank&&(0,F.r1)(i.names,e.names)&&(0,F.r1)(i.ids,e.ids)&&(0,F.r1)(i.timestamps,e.timestamps)&&(0,F.r1)(i.units,e.units)&&(0,F.r1)(i.scales,e.scales)&&(0,F.wm)(i.boundingBoxes,e.boundingBoxes,mC)&&(0,F.wm)(i.coordinateArrays,e.coordinateArrays,fC)}function xV(i,e,t){parseFixedLengthArray(i,t,(n,s)=>{const r=unitFromJson(n);return e[s]=r.exponent,r.unit})}function Oe(i){const{names:e,units:t,scales:n}=i,{valid:s=!0,rank:r=e.length,timestamps:o=e.map(()=>Number.NEGATIVE_INFINITY),ids:a=e.map((u,h)=>-h),boundingBoxes:l=[]}=i,{coordinateArrays:c=new Array(r)}=i,{bounds:d=CC(l,r)}=i;return{valid:s,rank:r,names:e,timestamps:o,ids:a,units:t,scales:n,boundingBoxes:l,bounds:d,coordinateArrays:c}}const Fn=Oe({valid:!1,names:[],units:[],scales:Mh,boundingBoxes:[]}),ki=Oe({valid:!0,names:[],units:[],scales:Mh,boundingBoxes:[]});function vC(i){const[e,t]=(0,f.J6)(i,2),n=(0,f.Mo)(e),s=(0,f.zr)(t),r=ir.get(s);if(r===void 0)throw new Error(`Invalid unit: ${JSON.stringify(s)}`);return{unit:r.unit,scale:Fl(n,r.exponent)}}function uo(i,e=!1){if(i===void 0)return Fn;(0,f.Rf)(i);const t=Yl(Object.keys(i),e),n=t.length,s=new Array(n),r=new Float64Array(n),o=new Array(n);for(let a=0;a{if(Array.isArray(l)){const{unit:c,scale:d}=vC(l);s[a]=c,r[a]=d}else{(0,f.Rf)(l);const c=(0,f.cQ)(l,"coordinates",f.VH),d=(0,f.cQ)(l,"labels",f.si),u=c.length;if(u!==d.length)throw new Error(`Length of coordinates array (${u}) does not match length of labels array (${d.length})`);s[a]="",r[a]=1,o[a]={explicit:!0,...gC(c,d)}}});return Oe({valid:!1,names:t,units:s,scales:r,coordinateArrays:o})}function Gl(i){const{rank:e}=i;if(e===0)return;const{names:t,units:n,scales:s,coordinateArrays:r}=i,o={};for(let a=0;as[l]>0&&a===0);return{lowerBounds:t,upperBounds:n,voxelCenterAtIntegerCoordinates:o}}function wC(i,e,t){const{transform:n,box:s}=i,r=t.length,o=s.lowerBounds.length,a=new Float64Array((o+1)*e);for(let l=0;lEC(n,e,i.scales,t))}function Hl(i,e,t){const n=Oe({valid:i.valid,rank:t.rank,ids:t.ids,names:t.names,timestamps:t.timestamps,scales:t.scales,units:t.units,boundingBoxes:$h(i,e,t.scales),coordinateArrays:t.coordinateArrays});return co(n,t)?t:n}function Jl(i,e=!1){if(e){const t=Number(i);if(Number.isInteger(t)&&t>=0)return!0}return i.match(/^[a-zA-Z][a-zA-Z_0-9]*['^]?$/)!==null}function ho(i,e=!1){const t=new Set;for(const n of i){if(!Jl(n,e)||t.has(n))return!1;t.add(n)}return!0}function jl(i){const e=i.length,t=new Array(e);t.fill(!0);for(let n=0;n{const Q=s.indexOf(z);return Q!==-1?d[Q]=!1:u.push(Y),Q}),{outputSpace:p}=i,{names:m,units:g,scales:v,ids:y,timestamps:S,coordinateArrays:w}=p,b=d,x=[],E=[],D=new Float64Array(o),I=[],L=[],N=new Array(o);let k=0;const O=new Float64Array((o+1)**2);O[O.length-1]=1;for(let z=0;z`${Y}`),units:k.units,scales:k.scales,coordinateArrays:k.coordinateArrays});this.value={rank:O,transform:e.transform||De.DA(Float64Array,O+1),sourceRank:e.sourceRank,outputSpace:e.outputSpace,inputSpace:V};return}const{inputSpace:t,sourceRank:n,outputSpace:s,transform:r,rank:o}=this.defaultTransform,{inputSpace:a,sourceRank:l,outputSpace:c,transform:d}=e,u=e.outputSpace.rank,h=t.names,p=a!==void 0?a.names:h,m=new Array(n);for(let k=0;k=l&&(O=-1),m[k]=O}const g=u-l+n;for(let k=l;k=n?V=0:V=r[o*(o+1)+k]*(s.scales[k]/D[k]):V=d[u*(u+1)+O],L[g*(g+1)+k]=V;for(let z=0;z=n||Y>=n?Q=O===Y?1:0:Q=r[z*(o+1)+k]:Q=d[Y*(u+1)+O],L[z*(g+1)+k]=Q}}const N=t.boundingBoxes.map(k=>Uh(k,o,g));for(let k=n;kkC(n,e));if(!ho(t,e))throw new Error(`Invalid dimensions: ${JSON.stringify(t)}`);return t}class Ql{constructor(e,t){this.combined=e,this.bindings=new Set,this.retainCount=0,this.prevCombined=this.combined.value,this.dimensionRefCounts=new Map,this.handleCombinedChanged=()=>{this.combined.value!==this.prevCombined&&this.update()},this.includeDimensionPredicate_=t}getRenameValidity(e){const t=this.combined.value.names,n=jl(e),s=e.length;for(let r=0;r0?1:0;if(t.size===0&&!n){e.value=Fn;return}const s=this.includeDimensionPredicate_,r=e.value;let o=Array.from(r.names),a=Array.from(r.units),l=Array.from(r.scales),c=Array.from(r.ids),d=Array.from(r.timestamps),u=r.names.map(()=>n?1:0);const h=[];let p=!1;for(const x of t){const{space:{value:E},prevValue:D,mappedDimensionIds:I}=x;p=p||E.valid;const{names:L,units:N,scales:k,ids:O,timestamps:V}=E,z=[],Y=[];h.push(Y),x.mappedDimensionIds=z,x.prevValue=E;const Q=L.length;for(let X=0;Xu[D]!==0;o=o.filter(x),a=a.filter(x),l=l.filter(x),c=c.filter(x),d=d.filter(x),u=u.filter(x),v=o.length}const y=[],S=new Array(v);for(let x=0,E=r.rank;xo.indexOf(k));for(const k of I)y.push(wC(k,v,N));for(let k=0;k{--this.retainCount===0&&this.update()}}bind(e){const t={space:e,mappedDimensionIds:[],prevValue:void 0},{bindings:n}=this;n.size===0&&this.combined.changed.add(this.handleCombinedChanged),n.add(t);const s=e.changed.add(()=>{e.value!==t.prevValue&&this.update()}),r=()=>{s();const{bindings:o}=this;o.delete(t),o.size===0&&this.combined.changed.remove(this.handleCombinedChanged),this.update()};return this.update(),r}}function Jh(i,e,t,n,s){const r=s.length,o=new i((r+1)**2);o[o.length-1]=1;for(let a=0;a{(0,f.Vr)(t,o),C.Yu.normalize(t,t)}),(0,f.MM)(i,"translation",o=>{(0,f.Vr)(n,o)}),(0,f.MM)(i,"scale",o=>{(0,f.Vr)(s,o)});const r=C.pB.create();C.pB.fromRotationTranslationScale(r,t,n,s),e.set(r)}return{sourceRank:3,transform:e,outputSpace:Oe({valid:!0,names:["x","y","z"],units:["m","m","m"],scales:Float64Array.of(1e-9,1e-9,1e-9)}),inputSpace:void 0}}function jh(i){if(i===void 0)return;const e=(0,f.Rf)(i),t=(0,f.cQ)(e,"outputDimensions",uo),n=t.rank,s=(0,f.cQ)(e,"sourceRank",a=>{if(a===void 0)return n;if(!Number.isInteger(a)||a<0||a>n)throw new Error(`Expected integer in range [0, ${n}] but received: ${JSON.stringify(a)}`);return a}),r=(0,f.MM)(e,"inputDimensions",a=>{const l=uo(a,!0);if(l.rank!==n)throw new Error(`Expected rank of ${n}, but received rank of: ${l.rank}`);return l});return{transform:(0,f.MM)(e,"matrix",a=>{const l=new Float64Array((n+1)**2),c=(0,f.J6)(a,n);l[l.length-1]=1;for(let d=0;dl===0))return{transform:a,box:n}}function Kl(i,e){const{ids:t,names:n,scales:s,units:r,timestamps:o,coordinateArrays:a}=i;return Oe({rank:e.length,valid:i.valid,ids:e.map(l=>t[l]),names:e.map(l=>n[l]),timestamps:e.map(l=>o[l]),scales:Float64Array.from(e,l=>s[l]),units:e.map(l=>r[l]),coordinateArrays:e.map(l=>a[l]),boundingBoxes:i.boundingBoxes.map(l=>AC(l,e,i.rank)).filter(l=>l!==void 0)})}function Qh(i,e,t){return e===t?i:Kl(i,(0,F.ep)(i.rank,t,e))}function Kh(i,e){const{transform:t,rank:n}=i,s=(0,C.PC)(t,n,[e]);if(s.length!==1)return;const[r]=s,o=Math.abs(t[(n+1)*r+e]),{inputSpace:a}=i;return{scale:a.scales[r]*o,unit:a.units[r]}}function qh(i,e){const{scales:t,units:n}=i.defaultInputSpace;return ea!==0))throw new Error("Lower bounds of channel coordinate space must all be 0");if(n.some(a=>!Number.isInteger(a)||a<=0||a>=4294967296))throw new Error("Upper bounds of channel coordinate space must all be positive integers");const s=new Uint32Array(n),r=$l(s),o=new Uint32Array(r*e);for(let a=0;ad[V]||`${V}`),y=m.map(V=>u[V]);if(g!==m.length)return{error:"Rank mismatch between model subspace dimensions ("+v.join(", ")+") and corresponding layer/global dimensions ("+y.join(", ")+")"};let S=Jh(Float32Array,c,o,m,h);const w=m.map(V=>u[V]),b=e.names.map(V=>w.indexOf(V)),x=i.names.map(V=>w.indexOf(V));ql(S,g,r,h,i,x),ql(S,g,r,h,e,b);const E=s.names.map(V=>w.indexOf(V));ql(S,g,r,h,s,E);const D=[],I=s.rank;if(n!==void 0){let{subsourceToModelSubspaceTransform:V}=n;p!==g&&(V=De.Aw(new Float32Array((g+1)**2),g,V,p)),S=De.lw(new Float32Array((g+1)**2),g+1,S,g+1,V,g+1,g+1,g+1,g+1)}const L=new Uint32Array(I),{lowerBounds:N,upperBounds:k,voxelCenterAtIntegerCoordinates:O}=s.bounds;for(let V=0;V=4294967296)return{error:`Channel dimension ${s.names[V]} must have lower bound of 0 and positive integer upper bound; current bounds are [${z}, ${Y}]`};L[V]=Y;const Q=E[V];let X=-1;if(Q!==-1)for(let ce=0;ceNC(r,o,a,n,l),[i,e,t,s===void 0?(0,_.XZ)(void 0):s],OC)}function _C(i,e,t,n){const{globalToRenderLayerDimensions:s}=t;for(let r=0;r<3;++r){let o=0;const a=n[r];if(a!==-1){const l=s[a];l!==-1&&(o=e[l])}i[r]=o}}function VC(i,e,t,n){const{globalToRenderLayerDimensions:s}=t;for(let r=0;r<3;++r){const o=n[r];if(o!==-1){const a=s[o];a!==-1&&(i[a]=e[r])}}}function TV(i,e,t,n){const{globalToRenderLayerDimensions:s}=t.modelTransform,{layerRank:r,chunkToLayerTransform:o}=t,a=r+1;for(let l=0;l<3;++l){let c=0;const d=n[l];if(d!==-1){const u=s[d];if(u!==-1){c=o[a*r+u];for(let h=0;hh[p]).join(",\xA0")}) and corresponding chunk dimensions (${Array.from(l,p=>u[p]).join(",\xA0")})`)}const c=C.pB.create();for(let u=0;u<3;++u){const h=o[u];if(h!==-1){for(let p=0;p=1)&&(l=!1)}return l}function DV(i,e,t,n){return scatterUpdate(i,e,n.globalToRenderLayerDimensions),scatterUpdate(i,t,n.localToRenderLayerDimensions),i}function BC(i,e,t){i.fill(0),i[15]=1;let n=!0;const{displayDimensionIndices:s}=e,{globalToRenderLayerDimensions:r,modelToRenderLayerTransform:o}=t,a=t.rank;for(let l=0;l<3;++l){const c=s[l];if(c===-1){n=!1;continue}const d=r[c];if(d===-1){n=!1;continue}i[l+12]=o[d+a*(a+1)];for(let u=0;u<3;++u)i[l+4*u]=o[d+(a+1)*u]}if(!n){const{globalDimensionNames:l}=e,c=Array.from(s.filter(d=>d!==-1),d=>l[d]).join(",\xA0");throw new Error(`Transform from model dimensions (${t.modelDimensionNames.join(",\xA0")}) to display dimensions (${c}) does not have full rank`)}}var Fe=G(5716);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var Ue=(i=>(i[i.GPU_MEMORY=0]="GPU_MEMORY",i[i.SYSTEM_MEMORY=1]="SYSTEM_MEMORY",i[i.SYSTEM_MEMORY_WORKER=2]="SYSTEM_MEMORY_WORKER",i[i.DOWNLOADING=3]="DOWNLOADING",i[i.QUEUED=4]="QUEUED",i[i.NEW=5]="NEW",i[i.FAILED=6]="FAILED",i[i.EXPIRED=7]="EXPIRED",i))(Ue||{});const Xl=8;var ri=(i=>(i[i.FIRST_TIER=0]="FIRST_TIER",i[i.FIRST_ORDERED_TIER=0]="FIRST_ORDERED_TIER",i[i.VISIBLE=0]="VISIBLE",i[i.PREFETCH=1]="PREFETCH",i[i.LAST_ORDERED_TIER=1]="LAST_ORDERED_TIER",i[i.RECENT=2]="RECENT",i[i.LAST_TIER=2]="LAST_TIER",i))(ri||{});const Zl=3;var ec=(i=>(i[i.totalTime=0]="totalTime",i[i.totalChunks=1]="totalChunks",i))(ec||{}),oi=(i=>(i[i.numChunks=0]="numChunks",i[i.systemMemoryBytes=1]="systemMemoryBytes",i[i.gpuMemoryBytes=2]="gpuMemoryBytes",i))(oi||{});const Un=3,LV=Xl*Zl*Un+2;function Pi(i,e){return i*Zl+e}function tp(i){return Xl*Zl*Un+i}const RV=1e13,FC="ChunkQueueManager",UC="ChunkManager",$C="ChunkSource.invalidate",GC="ChunkQueueManager.requestChunkStatistics",zC="ChunkManager.chunkLayerStatistics";class fo{constructor(){this.numVisibleChunksNeeded=0,this.numVisibleChunksAvailable=0,this.numPrefetchChunksNeeded=0,this.numPrefetchChunksAvailable=0}}var Qe=G(4104);/** + * @license + * Copyright 2024 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var np=(i=>(i[i.MEDIAN=0]="MEDIAN",i[i.MEAN=1]="MEAN",i[i.MAX=2]="MAX",i))(np||{});class WC{constructor(e=10,t=10){if(this.numStoredTimes=e,this.queryPoolSize=t,this.timeElapsedQueries=[],this.warnedAboutMissingExtension=!1,this.storedTimeDeltas=[],this.queryPoolSize<1)throw new Error(`Query pool size must be at least 1, but got ${t}.`)}getTimingExtension(e){const t=e.getExtension("EXT_disjoint_timer_query_webgl2");return t===null&&!this.warnedAboutMissingExtension&&(console.log("EXT_disjoint_timer_query_webgl2 extension not available. Cannot measure frame time."),this.warnedAboutMissingExtension=!0),t}startFrameTimeQuery(e,t){if(t===null)return null;const n=e.createQuery();return n!==null&&e.beginQuery(t.TIME_ELAPSED_EXT,n),n}endFrameTimeQuery(e,t,n){if(t!==null&&n!==null&&e.endQuery(t.TIME_ELAPSED_EXT),this.timeElapsedQueries.length>=this.queryPoolSize){const s=this.timeElapsedQueries.shift();s!=null&&e.deleteQuery(s)}this.timeElapsedQueries.push(n)}grabAnyFinishedQueryResults(e){const t=[];for(let n=0;n=0;n--)this.timeElapsedQueries.splice(n,1);this.storedTimeDeltas.length>this.numStoredTimes&&(this.storedTimeDeltas=this.storedTimeDeltas.slice(-this.numStoredTimes))}getLastFrameTimesInMs(e=10){return this.storedTimeDeltas.slice(-e)}getQueries(){return this.timeElapsedQueries}}class HC{constructor(e=10,t=8,n=16.666666666666668,s=15){this.numberOfStoredFrameDeltas=e,this.maxDownsamplingFactor=t,this.desiredFrameTimingMs=n,this.downsamplingPersistenceDurationInFrames=s,this.lastFrameTime=null,this.frameDeltas=[],this.downsamplingRates=new Map,this.frameCount=0,this.validateConstructorArguments();for(let r=1;r<=this.maxDownsamplingFactor;r*=2)this.downsamplingRates.set(r,-1/0)}validateConstructorArguments(){this.numberOfStoredFrameDeltas=Math.max(1,Math.round(this.numberOfStoredFrameDeltas)),this.maxDownsamplingFactor=Math.max(2,Math.round(this.maxDownsamplingFactor))}storeFrameDelta(e){this.frameDeltas.push(e),this.frameDeltas.length>this.numberOfStoredFrameDeltas&&this.frameDeltas.shift()}calculateMeanFrameTime(){return this.frameDeltas.reduce((e,t)=>e+t,0)/this.frameDeltas.length}calculateMedianFrameTime(){const e=this.frameDeltas.slice().sort((n,s)=>n-s),t=Math.floor(e.length/2);return e.length%2===1?e[t]:(e[t-1]+e[t])/2}calculateMaxFrameTime(){return Math.max(...this.frameDeltas)}updateMaxTrackedDownsamplingRate(e){this.downsamplingRates.set(e,this.frameCount);let t=1;for(const[n,s]of this.downsamplingRates)this.frameCount-s<=this.downsamplingPersistenceDurationInFrames&&(t=n);return t}resetForNewFrameSet(){this.lastFrameTime=null,this.frameCount=0,this.downsamplingRates.forEach((e,t)=>{this.downsamplingRates.set(t,-1/0)})}addFrame(e=Date.now()){if(this.lastFrameTime!==null){const t=e-this.lastFrameTime;t>0&&this.storeFrameDelta(t)}this.lastFrameTime=e,this.frameCount++}calculateFrameTimeInMs(e=2){if(this.frameDeltas.length===0)return 0;switch(e){case 0:return this.calculateMedianFrameTime();case 1:return this.calculateMeanFrameTime();case 2:return this.calculateMaxFrameTime()}}calculateDownsamplingRate(e=1){const t=this.calculateFrameTimeInMs(e);if(t===0)return Math.min(4,this.maxDownsamplingFactor);let n=Math.max(t/this.desiredFrameTimingMs,1);return n=Math.min(Math.pow(2,Math.round(Math.log2(n))),this.maxDownsamplingFactor),this.updateMaxTrackedDownsamplingRate(n)}getFrameDeltas(){return this.frameDeltas}getFrameCount(){return this.frameCount}getDownsamplingRates(){return this.downsamplingRates}setFrameDeltas(e,t=!0){this.frameDeltas=e.slice(-this.numberOfStoredFrameDeltas),t&&this.frameCount++}}var JC=G(310);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const jC=300;class tc{constructor(){this.width=0,this.height=0,this.logicalWidth=0,this.logicalHeight=0,this.visibleLeftFraction=0,this.visibleTopFraction=0,this.visibleWidthFraction=0,this.visibleHeightFraction=0}}function ip(i,e){const t=1/i.visibleWidthFraction,n=1/i.visibleHeightFraction,s=-1-(-1+2*i.visibleLeftFraction)*t;let r=-1-(-1+2*i.visibleTopFraction)*n;r=-r,e[0]=e[0]*t+e[3]*s,e[4]=e[4]*t+e[7]*s,e[8]=e[8]*t+e[11]*s,e[12]=e[12]*t+e[15]*s,e[1]=e[1]*n+e[3]*r,e[5]=e[5]*n+e[7]*r,e[9]=e[9]*n+e[11]*r,e[13]=e[13]*n+e[15]*r}function sp(i,e){return i.width===e.width&&i.height===e.height&&i.logicalWidth===e.logicalWidth&&i.logicalHeight===e.logicalHeight&&i.visibleLeftFraction===e.visibleLeftFraction&&i.visibleTopFraction===e.visibleTopFraction}class rp extends T.O8{constructor(e,t,n){super(),this.context=e,this.element=t,this.visibility=n,this.boundsGeneration=-1,this.canvasRelativeClippedLeft=0,this.canvasRelativeClippedTop=0,this.canvasRelativeLogicalLeft=0,this.canvasRelativeLogicalTop=0,this.renderViewport=new tc,this.monitorState={},this.gl=e.gl,e.addPanel(this)}scheduleRedraw(){this.visible&&this.context.scheduleRedraw()}ensureBoundsUpdated(){const{context:e}=this;e.ensureBoundsUpdated();const{boundsGeneration:t}=e;if(t===this.boundsGeneration)return;this.boundsGeneration=t;const{element:n}=this,s=n.getBoundingClientRect();e.ensureMonitorPanel(n,this.monitorState,s);const r=e.container,o=e.canvasRect,{canvas:a}=e,{width:l,height:c}=a,d=l/o.width,u=c/o.height,h=o.left,p=o.top,m=this.canvasRelativeLogicalLeft=Math.round((s.left-h)*d+n.clientLeft),g=this.canvasRelativeLogicalTop=Math.round((s.top-p)*u+n.clientTop),v=n.clientWidth,y=n.clientHeight,S=m+v,w=g+y;let b=g,x=m,E=S,D=w;for(let k=n.parentElement;k!==null&&k!==r;k=k.parentElement){const O=k.getBoundingClientRect();O.x===0&&O.y===0&&O.width===0&&O.height===0||(x=Math.max(x,(O.left-h)*d),b=Math.max(b,(O.top-p)*u),E=Math.min(E,(O.right-h)*d),D=Math.min(D,(O.bottom-p)*u))}b=this.canvasRelativeClippedTop=Math.round(Math.max(b,0)),x=this.canvasRelativeClippedLeft=Math.round(Math.max(x,0)),E=Math.round(Math.min(E,l)),D=Math.round(Math.min(D,c));const I=this.renderViewport,L=I.width=Math.max(0,E-x),N=I.height=Math.max(0,D-b);I.logicalWidth=v,I.logicalHeight=y,I.visibleLeftFraction=(x-m)/v,I.visibleTopFraction=(b-g)/y,I.visibleWidthFraction=L/v,I.visibleHeightFraction=N/y}setGLClippedViewport(){const{gl:e,canvasRelativeClippedTop:t,canvasRelativeClippedLeft:n,renderViewport:{width:s,height:r}}=this,o=t+r;e.enable(WebGL2RenderingContext.SCISSOR_TEST);const a=this.context.canvas.height-o;e.viewport(n,a,s,r),e.scissor(n,a,s,r)}setGLLogicalViewport(){const{gl:e,renderViewport:{width:t,height:n,logicalWidth:s,logicalHeight:r}}=this,o=this.context.canvas.height;e.enable(WebGL2RenderingContext.SCISSOR_TEST),e.viewport(this.canvasRelativeLogicalLeft,o-(this.canvasRelativeLogicalTop+r),s,r),e.scissor(this.canvasRelativeClippedLeft,o-(this.canvasRelativeClippedTop+n),t,n)}disposed(){this.context.unmonitorPanel(this.element,this.monitorState),this.context.removePanel(this),super.disposed()}get visible(){return this.visibility.visible}getDepthArray(){}get shouldDraw(){if(!this.visible)return!1;const{element:e}=this;return!(e.clientWidth===0||e.clientHeight===0||e.offsetWidth===0||e.offsetHeight===0)}get drawOrder(){return 0}}class nc extends rp{constructor(e,t,n){super(e,t,n),this.canvas=document.createElement("canvas"),this.canvasRenderingContext=this.canvas.getContext("2d");const{canvas:s}=this;t.appendChild(s),t.style.position="relative",s.style.position="absolute",s.style.left="0",s.style.right="0",s.style.top="0",s.style.bottom="0"}draw(){this.drawIndirect();const{renderViewport:e,canvas:t}=this,{logicalWidth:n,logicalHeight:s}=e;t.width=n,t.height=s;const{canvasRenderingContext:r}=this;r?.drawImage(this.context.canvas,this.canvasRelativeLogicalLeft,this.canvasRelativeLogicalTop,n,s,0,0,n,s)}}class YC extends _.DN{constructor(){super(Float64Array.of(0,0,1,1),e=>(0,f.Xu)(new Float64Array(4),e,f.xU))}toJSON(){const{value:e}=this,[t,n,s,r]=e;if(!(t===0&&n===0&&s===1&&r===1))return Array.from(e)}}class QC extends T.O8{constructor(e){super(),this.container=e,this.canvas=document.createElement("canvas"),this.updateStarted=new j.IY,this.updateFinished=new j.IY,this.continuousCameraMotionStarted=new j.IY,this.continuousCameraMotionFinished=new j.IY,this.changed=this.updateFinished,this.panels=new Set,this.resizeGeneration=0,this.boundsGeneration=-1,this.framerateMonitor=new WC,this.continuousCameraMotionInProgress=!1,this.orderedPanels=[],this.frameNumber=0,this.resizeCallback=()=>{++this.resizeGeneration,this.scheduleRedraw()},this.resizeObserver=new ResizeObserver(this.resizeCallback),this.debouncedEndContinuousCameraMotion=this.registerCancellable((0,Fe.A)(()=>{this.continuousCameraMotionInProgress=!1,this.continuousCameraMotionFinished.dispatch()},jC)),this.scheduleRedraw=this.registerCancellable((0,Qe.t)(()=>this.draw()));const{canvas:t,resizeObserver:n}=this;e.style.position="relative",t.style.position="absolute",t.style.top="0px",t.style.left="0px",t.style.width="100%",t.style.height="100%",t.style.zIndex="0",n.observe(t),e.appendChild(t),this.registerEventListener(t,"webglcontextlost",s=>{console.log(`Lost WebGL context: ${s.statusMessage}`),s.preventDefault()}),this.registerEventListener(t,"webglcontextrestored",()=>{console.log("WebGL context restored"),window.location.reload()}),this.gl=(0,JC.y)(t)}ensureMonitorPanel(e,t,n){t.addedToResizeObserver||(this.resizeObserver.observe(e),t.addedToResizeObserver=!0);const s=this.rootRect,r=s.top-n.top,o=s.left-n.left,a=n.right-s.right,l=n.bottom-s.bottom,c=`${r}px ${a}px ${l}px ${o}px`;t.intersectionObserverMargin!==c&&(t.intersectionObserverMargin=c,t.intersectionObserver?.disconnect(),(t.intersectionObserver=new IntersectionObserver(this.resizeCallback,{root:this.container,rootMargin:c,threshold:[.93,.94,.95,.96,.97,.98,.99,1]})).observe(e))}unmonitorPanel(e,t){t.addedToResizeObserver&&this.resizeObserver.unobserve(e),t.intersectionObserver?.disconnect()}flagContinuousCameraMotion(){this.continuousCameraMotionInProgress||this.continuousCameraMotionStarted.dispatch(),this.continuousCameraMotionInProgress=!0,this.debouncedEndContinuousCameraMotion()}get isContinuousCameraMotionInProgress(){return this.continuousCameraMotionInProgress}applyWindowedViewportToElement(e,t){const[n,s,r,o]=t,a=1/r,l=1/o;e.style.position="absolute",e.style.top=`${-l*s*100}%`,e.style.left=`${-a*n*100}%`,e.style.width=`${a*100}%`,e.style.height=`${l*100}%`,++this.resizeGeneration,this.scheduleRedraw()}isReady(){for(const e of this.panels)if(e.visible&&!e.isReady())return!1;return!0}makeCanvasOverlayElement(){const e=document.createElement("div");return e.style.position="absolute",e.style.top="0px",e.style.left="0px",e.style.width="100%",e.style.height="100%",e.style.zIndex="2",this.container.appendChild(e),e}disposed(){this.orderedPanels.length=0,this.resizeObserver.disconnect()}addPanel(e){this.panels.add(e),this.orderedPanels.length=0,++this.resizeGeneration,this.scheduleRedraw()}removePanel(e){this.panels.delete(e),this.orderedPanels.length=0,++this.resizeGeneration,this.scheduleRedraw()}ensureBoundsUpdated(){const{resizeGeneration:e}=this;if(this.boundsGeneration===e)return;const{canvas:t}=this;t.width=t.offsetWidth,t.height=t.offsetHeight,this.canvasRect=t.getBoundingClientRect(),this.rootRect=this.container.getBoundingClientRect(),this.boundsGeneration=e}draw(){++this.frameNumber,this.updateStarted.dispatch();const e=this.gl,t=this.framerateMonitor.getTimingExtension(e),n=this.framerateMonitor.startFrameTimeQuery(e,t);this.ensureBoundsUpdated(),this.gl.clearColor(0,0,0,0),e.clear(e.COLOR_BUFFER_BIT|e.DEPTH_BUFFER_BIT);const{orderedPanels:s,panels:r}=this;s.length!==r.size&&(s.push(...r),s.sort((o,a)=>o.drawOrder-a.drawOrder));for(const o of s){if(!o.shouldDraw)continue;o.ensureBoundsUpdated();const{renderViewport:a}=o;a.width===0||a.height===0||o.draw()}e.disable(e.SCISSOR_TEST),this.gl.clearColor(1,1,1,1),this.gl.colorMask(!1,!1,!1,!0),e.clear(e.COLOR_BUFFER_BIT),this.gl.colorMask(!0,!0,!0,!0),this.updateFinished.dispatch(),this.framerateMonitor.endFrameTimeQuery(e,t,n),this.framerateMonitor.grabAnyFinishedQueryResults(e)}getDepthArray(){const{width:e,height:t}=this.canvas,n=new Float32Array(e*t);for(const s of this.panels){if(!s.shouldDraw)continue;const r=s.getDepthArray();if(r===void 0)continue;const{canvasRelativeClippedTop:o,canvasRelativeClippedLeft:a,renderViewport:{width:l,height:c}}=s;for(let d=0;d(i[i.info=0]="info",i[i.warning=1]="warning",i[i.error=2]="error",i))(Tn||{});class kV{}class ai{constructor(){this.changed=new j.IY,this.messages=[],this.children=[]}addMessage(e){this.messages.push(e),this.changed.dispatch()}clearMessages(){const{messages:e}=this;e.length!==0&&(e.length=0,this.changed.dispatch())}isEmpty(){return this.messages.length===0&&!this.children.some(e=>!e.isEmpty())}addChild(e){return this.children.push(e),e.changed.add(this.changed.dispatch),e.isEmpty()||this.changed.dispatch(),()=>{const{children:t}=this;t.splice(t.indexOf(e),1),e.changed.remove(this.changed.dispatch),e.isEmpty()||this.changed.dispatch()}}*[Symbol.iterator](){yield*this.messages;for(const e of this.children)yield*e}}var Je=G(4509);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const mo=!(typeof Window<"u"&&self instanceof Window),lp=!1,cp=!1,ic="rpc.promise.response",dp="rpc.promise.cancel",up="rpc.ready",hp=new Map;function pt(i,e){hp.set(i,e)}class qC extends Error{constructor(e,t){super(t),this.name=e,this.message=t}}function pp(i,e){pt(i,function(t){const n=t.id,s=new Je.Qi,r=e.call(this,t,s);this.set(n,{promise:r,cancellationToken:s}),r.then(({value:o,transfers:a})=>{this.delete(n),this.invoke(ic,{id:n,value:o},a)},o=>{this.delete(n),this.invoke(ic,{id:n,error:o.message,errorName:o.name})})})}pt(dp,function(i){const e=i.id,t=this.get(e);if(t!==void 0){const{cancellationToken:n}=t;n.cancel()}}),pt(ic,function(i){const e=i.id,{resolve:t,reject:n}=this.get(e);this.delete(e),Object.prototype.hasOwnProperty.call(i,"value")?t(i.value):i.errorName===Je.wS.name?n(Je.wS):n(new qC(i.errorName,i.error))}),pt(up,function(i){this.onPeerReady()});const XC=mo?-1:0;class ZC{constructor(e,t){this.target=e,this.objects=new Map,this.nextId=XC,t&&(this.queue=[]),e.onmessage=n=>{const s=n.data;cp&&console.log("Received message",s),hp.get(s.functionName).call(this,s)}}sendReady(){this.invoke(up,{})}onPeerReady(){const{queue:e}=this;if(e!==void 0){this.queue=void 0;for(const{data:t,transfers:n}of e)this.target.postMessage(t,n)}}get numObjects(){return this.objects.size}set(e,t){this.objects.set(e,t)}delete(e){this.objects.delete(e)}get(e){return this.objects.get(e)}getRef(e){const t=e.id,n=this.get(t);return n.referencedGeneration=e.gen,n.addRef(),n}getOptionalRef(e){if(e===void 0)return;const t=e.id,n=this.get(t);return n.referencedGeneration=e.gen,n.addRef(),n}invoke(e,t,n){t.functionName=e,cp&&console.trace("Sending message",t);const{queue:s}=this;if(s!==void 0){s.push({data:t,transfers:n});return}this.target.postMessage(t,n)}promiseInvoke(e,t,n=Je.fx,s){return(0,Je.gI)(n,(r,o,a)=>{const l=t.id=this.newId();this.set(l,{resolve:r,reject:o}),this.invoke(e,t,s),a.add(()=>{this.invoke(dp,{id:l})})})}newId(){return mo?this.nextId--:this.nextId++}}class hn extends T.O8{constructor(){super(...arguments),this.rpc=null,this.rpcId=null}initializeSharedObject(e,t=e.newId()){this.rpc=e,this.rpcId=t,this.isOwner=!1,e.set(t,this)}initializeCounterpart(e,t={}){this.initializeSharedObject(e),this.unreferencedGeneration=0,this.referencedGeneration=0,this.isOwner=!0,t.id=this.rpcId,t.type=this.RPC_TYPE_ID,e.invoke("SharedObject.new",t)}dispose(){super.dispose()}addCounterpartRef(){return{id:this.rpcId,gen:++this.referencedGeneration}}refCountReachedZero(){this.isOwner===!0?this.referencedGeneration===this.unreferencedGeneration&&this.ownerDispose():this.isOwner===!1?this.rpc.invoke("SharedObject.refCountReachedZero",{id:this.rpcId,gen:this.referencedGeneration}):super.refCountReachedZero()}ownerDispose(){lp&&console.log(`[${mo}] #rpc object = ${this.rpc.numObjects}`);const{rpc:e,rpcId:t}=this;super.refCountReachedZero(),e.delete(t),e.invoke("SharedObject.dispose",{id:t})}counterpartRefCountReachedZero(e){this.unreferencedGeneration=e,this.refCount===0&&e===this.referencedGeneration&&this.ownerDispose()}}function ew(i,e,t={}){e!=null&&i.initializeSharedObject(e,t.id)}class vo extends hn{constructor(e,t={}){super(),ew(this,e,t)}}pt("SharedObject.dispose",function(i){const e=this.get(i.id);if(e.refCount!==0)throw new Error("Attempted to dispose object with non-zero reference count.");lp&&console.log(`[${mo}] #rpc objects: ${this.numObjects}`),e.disposed(),this.delete(e.rpcId),e.rpcId=null,e.rpc=null}),pt("SharedObject.refCountReachedZero",function(i){const e=this.get(i.id),t=i.gen;e.counterpartRefCountReachedZero(t)});const fp=new Map;function Zt(i){return e=>{e.prototype.RPC_TYPE_ID=i}}function yo(i){return e=>{if(i!==void 0)e.prototype.RPC_TYPE_ID=i;else if(i=e.prototype.RPC_TYPE_ID,i===void 0)throw new Error("RPC_TYPE_ID should have already been defined");fp.set(i,e)}}pt("SharedObject.new",function(i){const e=this,t=i.type,n=fp.get(t),s=new n(e,i);--s.refCount});var tw=Object.defineProperty,nw=Object.getOwnPropertyDescriptor,iw=(i,e,t,n)=>{for(var s=n>1?void 0:n?nw(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&tw(e,t,s),s};/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const gp="SharedWatchableValue.changed";let ft=class extends vo{constructor(i,e={}){super(i,e),this.updatingValue_=!1,i!==void 0&&(this.base=new _.B0(e.value),this.setupChangedHandler())}initializeCounterpart(i,e={}){e.value=this.value,super.initializeCounterpart(i,e)}setupChangedHandler(){this.registerDisposer(this.base.changed.add(()=>{if(this.updatingValue_)this.updatingValue_=!1;else{const{rpc:i}=this;i!==null&&i.invoke(gp,{id:this.rpcId,value:this.value})}}))}static makeFromExisting(i,e){const t=new ft;return t.base=e,t.setupChangedHandler(),t.initializeCounterpart(i),t}static make(i,e){return ft.makeFromExisting(i,new _.B0(e))}get value(){return this.base.value}set value(i){this.base.value=i}get changed(){return this.base.changed}};ft=iw([yo("SharedWatchableValue")],ft),pt(gp,function(i){const e=this.get(i.id);e.updatingValue_=!0,e.base.value=i.value,e.updatingValue_=!1});/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class vt extends _.B0{constructor(e=Number.NEGATIVE_INFINITY){super(e)}get visible(){return this.value===Number.POSITIVE_INFINITY}get ignored(){return this.value===Number.NEGATIVE_INFINITY}}vt.VISIBLE=Number.POSITIVE_INFINITY,vt.IGNORED=Number.NEGATIVE_INFINITY;class or extends vt{constructor(){super(...arguments),this.contributors=new Map}add(e){const{contributors:t}=this,n=e.changed.add(()=>{this.update()}),s=()=>{t.delete(s),n(),this.update()};return t.set(s,e),this.update(),s}update(){let e=Number.NEGATIVE_INFINITY;for(const t of this.contributors.values())e=Math.max(e,t.value);this.value=e}}function ar(i){return class extends i{constructor(){super(...arguments),this.visibility=new or}initializeCounterpart(e,t={}){t.visibility=this.registerDisposer(ft.makeFromExisting(e,this.visibility)).rpcId,super.initializeCounterpart(e,t)}}}var sw=Object.defineProperty,rw=Object.getOwnPropertyDescriptor,ow=(i,e,t,n)=>{for(var s=n>1?void 0:n?rw(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&sw(e,t,s),s};/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var li=(i=>(i[i.DATA=0]="DATA",i[i.ANNOTATION=1]="ANNOTATION",i[i.DEFAULT_ANNOTATION=2]="DEFAULT_ANNOTATION",i))(li||{});function aw(){return new _._Y([0,1,2])}class mp extends T.O8{constructor(){super(...arguments),this.role=0,this.messages=new ai,this.layerChanged=new j.IY,this.redrawNeeded=new j.IY,this.layerChunkProgressInfo=new fo}handleAction(e){}getValueAt(e){}transformPickedValue(e){return e.pickedValue}updateMouseState(e,t,n,s){}}class vp extends mp{constructor(){super(...arguments),this.visibility=new or}attach(e){}}function lr(i,e,t){let{state:n}=t;if(n===void 0||n.transform!==i||n.displayDimensionRenderInfo!==e){if(t.messages.clearMessages(),n=t.state={transform:i,displayDimensionRenderInfo:e,modelTransform:void 0},i.error!==void 0){t.messages.addMessage({severity:Tn.error,message:i.error});return}try{const s=C.pB.create();BC(s,e,i),n.modelTransform=s}catch(s){t.messages.addMessage({severity:Tn.error,message:s.message})}}return n.modelTransform}class yp extends T.O8{constructor(e){super(),this.renderViewport=new tc,this.changed=new j.HN;const{parametersConstructor:t=op,navigationState:n,update:s,isEqual:r=KC}=e;this.oldValue_=new t,this.value_=new t;const o=()=>{const{oldValue_:l,value_:c}=this;l.displayDimensionRenderInfo=n.displayDimensionRenderInfo.value,Object.assign(l,this.renderViewport);let{globalPosition:d}=l;const u=n.position.value,h=u.length;d.length!==h&&(l.globalPosition=d=new Float32Array(h)),d.set(u),s(l,n),!r(l,c)&&(this.value_=l,this.oldValue_=c,this.changed.dispatch(c,l))},a=this.update=this.registerCancellable((0,Fe.A)(o,0));this.registerDisposer(n.changed.add(a)),o()}setViewport(e){sp(e,this.renderViewport)||(Object.assign(this.renderViewport,e),this.update())}get value(){return this.update.flush(),this.value_}}let So=class extends hn{constructor(i,e,t=10){super(),this.base=e,this.updateInterval=t,this.prevDisplayDimensionRenderInfo=void 0,this.update=this.registerCancellable((0,Fe.A)((n,s)=>{let r;if(s.displayDimensionRenderInfo!==this.prevDisplayDimensionRenderInfo)r=s,this.prevDisplayDimensionRenderInfo=s.displayDimensionRenderInfo;else{const{displayDimensionRenderInfo:o,...a}=s;r=a}this.rpc.invoke(go.kg,{id:this.rpcId,value:r})},this.updateInterval)),this.initializeCounterpart(i,{value:e.value}),this.registerDisposer(e.changed.add(this.update))}flush(){this.update.flush()}};So=ow([Zt(go.Bh)],So);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class nt{constructor(e,t=e){this.value_=e,this.defaultValue=t,this.changed=new j.IY}get value(){return this.value_}set value(e){e!==this.value_&&(this.value_=e,this.changed.dispatch())}toggle(){this.value=!this.value}toJSON(){const{value_:e}=this;if(e!==this.defaultValue)return this.value_}restoreState(e){if(e===!0||e===!1){this.value=e;return}this.value=this.defaultValue}reset(){this.value=this.defaultValue}}class pn extends T.O8{constructor(e,t={}){super(),this.model=e,this.element=document.createElement("input");const{element:n}=this;n.type="checkbox";const s=()=>{const r=this.model.value;this.element.checked=r,(t.enableTitle!==void 0||t.disableTitle!==void 0)&&(this.element.title=(r?t.enableTitle:t.disableTitle)??"")};this.registerDisposer(e.changed.add(s)),s(),this.registerEventListener(n,"change",function(r){e.value=this.checked}),n.addEventListener("mousedown",r=>{r.preventDefault()})}disposed(){const{element:e}=this,{parentElement:t}=e;t&&t.removeChild(e),super.disposed()}}class en extends T.O8{constructor(e,t){super(),this.model=e,this.element=t,this.initialDisplay=this.element.style.display,this.updateVisibility(),this.registerDisposer(e.changed.add(this.registerCancellable((0,Fe.A)(()=>this.updateVisibility(),0))))}updateVisibility(){this.element.style.display=this.model.value?this.initialDisplay:"none"}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function bo(i){try{return i()}catch(e){return{error:e.message}}}function sc(i){if(i.error!==void 0)throw new Error(i.error);return i}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class rc extends T.O8{constructor(e,t){if(super(),this.register=e,this.changed=new j.IY,this.disposerMap=new Map,t===void 0)this.map=new Map;else{const n=this.map=new Map(t),{disposerMap:s}=this;for(const[r,o]of n){const a=new T.O8;s.set(r,a),e(a,o,r)}}}get value(){return this.map}set(e,t){const{map:n,disposerMap:s}=this;let r=s.get(e);return r!==void 0&&r.dispose(),r=new T.O8,s.set(e,r),n.set(e,t),this.register(r,t,e),this.changed.dispatch(),this}delete(e){const{map:t,disposerMap:n}=this,s=n.get(e);return s!==void 0?(s.dispose(),n.delete(e),t.delete(e),this.changed.dispatch(),!0):!1}get(e){return this.map.get(e)}has(e){return this.map.has(e)}get size(){return this.map.size}[Symbol.iterator](){return this.map[Symbol.iterator]()}clear(){const{map:e,disposerMap:t}=this;if(e.size>0){for(const n of t.values())n.dispose();e.clear(),t.clear(),this.changed.dispatch()}}values(){return this.map.values()}keys(){return this.map.keys()}disposed(){const{map:e,disposerMap:t}=this;for(const n of t.values())n.dispose();e.clear(),t.clear(),super.disposed()}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Sp=Symbol("objectId");let lw=0;function xt(i){if(i instanceof Object){let e=i[Sp];return e===void 0&&(e=i[Sp]=lw++),`o${e}`}return""+JSON.stringify(i)}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const oc=!1;var bp=(i=>(i[i.VERTEX=WebGL2RenderingContext.VERTEX_SHADER]="VERTEX",i[i.FRAGMENT=WebGL2RenderingContext.FRAGMENT_SHADER]="FRAGMENT",i))(bp||{});function cw(i){i=i.replace("\0","");const e=[];for(let t of i.split(` +`)){let n=t.match(/^ERROR:\s*(\d+):(\d+)\s*(.+)$/);n!==null?e.push({message:n[3].trim(),file:parseInt(n[1],10),line:parseInt(n[2],10)}):(n=t.match(/^ERROR:\s*(.+)$/),n!==null?e.push({message:n[1]}):(t=t.trim(),t&&e.push({message:t})))}return e}class dw extends Error{constructor(e,t,n,s){const r=`Error compiling ${bp[e].toLowerCase()} shader: ${n}`;super(r),this.name="ShaderCompilationError",this.log=n,this.message=r,this.shaderType=e,this.source=t,this.errorMessages=s}}class uw extends Error{constructor(e,t,n){const s=`Error linking shader: ${n}`;super(s),this.name="ShaderLinkError",this.log=n,this.message=s,this.vertexSource=e,this.fragmentSource=t}}function Cp(i,e,t){const n=i.createShader(t);if(i.shaderSource(n,e),i.compileShader(n),!i.getShaderParameter(n,i.COMPILE_STATUS)){const s=i.getShaderInfoLog(n)||"";if(oc){const r=e.replace("<","<").replace(">",">").split(` +`);let o="
";o+=s.replace("<","<").replace(">",">")+`
+`,r.forEach((l,c)=>{o+=`${c+1}: ${l}
+`}),o+=`
+
`,console.log(o);const a=window.open("about:blank","_blank");if(a!==null)try{a.document.write(o)}catch{}}throw new dw(t,e,s,cw(s))}return n}let ac;class hw extends T.O8{constructor(e,t,n,s,r,o){super(),this.gl=e,this.vertexSource=t,this.fragmentSource=n,this.attributes=new Map,this.uniforms=new Map,this.vertexShaderInputBinders={},this.transferFunctionTextures=new Map;const a=this.vertexShader=Cp(e,t,e.VERTEX_SHADER),l=this.fragmentShader=Cp(e,n,e.FRAGMENT_SHADER),c=e.createProgram();if(e.attachShader(c,a),e.attachShader(c,l),oc&&o?.length&&(e.transformFeedbackVaryings(c,o.map(h=>h.name),WebGL2RenderingContext.INTERLEAVED_ATTRIBS),this.vertexDebugOutputs=o),e.linkProgram(c),!e.getProgramParameter(c,e.LINK_STATUS)){const h=e.getProgramInfoLog(c)||"";throw new uw(t,n,h)}this.program=c;const{uniforms:d,attributes:u}=this;if(s)for(const h of s)d.set(h,e.getUniformLocation(c,h));if(r)for(const h of r)u.set(h,e.getAttribLocation(c,h))}uniform(e){return this.uniforms.get(e)}attribute(e){return this.attributes.get(e)}textureUnit(e){return this.textureUnits.get(e)}bind(){ac=this,this.gl.useProgram(this.program)}bindAndUpdateTransferFunctionTexture(e,t,n,s){const r=this.textureUnits.get(e);if(r===void 0)throw new Error(`Invalid texture unit symbol: ${e.toString()}`);const o=this.transferFunctionTextures.get(e);if(o===void 0)throw new Error(`Invalid transfer function texture symbol: ${e.toString()}`);return o.updateAndActivate({textureUnit:r,sortedControlPoints:t,dataType:n,lookupTableSize:s})}unbindTransferFunctionTextures(){const e=this.gl;for(const t of this.transferFunctionTextures.keys()){const n=this.textureUnits.get(t);n!==void 0&&(this.gl.activeTexture(e.TEXTURE0+n),this.gl.bindTexture(e.TEXTURE_2D,null))}}disposed(){const{gl:e}=this;e.deleteShader(this.vertexShader),this.vertexShader=void 0,e.deleteShader(this.fragmentShader),this.fragmentShader=void 0,e.deleteProgram(this.program),this.program=void 0,this.gl=void 0,this.attributes=void 0,this.uniforms=void 0,this.transferFunctionTextures=void 0}}function pw(i,e,t,n,s){if(i.drawArraysInstanced(e,t,n,s),!oc||!ac?.vertexDebugOutputs)return;const{vertexDebugOutputs:r}=ac;let o=0;for(const h of r)o+=fw[h.typeName];const a=i.createBuffer(),l=o*n*s;i.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER,a),i.bufferData(WebGL2RenderingContext.ARRAY_BUFFER,l,WebGL2RenderingContext.DYNAMIC_DRAW),i.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER,null),i.bindBufferBase(WebGL2RenderingContext.TRANSFORM_FEEDBACK_BUFFER,0,a),i.beginTransformFeedback(WebGL2RenderingContext.POINTS),i.enable(WebGL2RenderingContext.RASTERIZER_DISCARD),i.drawArraysInstanced(WebGL2RenderingContext.POINTS,t,n,s),i.disable(WebGL2RenderingContext.RASTERIZER_DISCARD),i.endTransformFeedback(),i.bindBufferBase(WebGL2RenderingContext.TRANSFORM_FEEDBACK_BUFFER,0,null),i.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER,a);const c=new Uint8Array(l);i.getBufferSubData(WebGL2RenderingContext.ARRAY_BUFFER,0,c,0,l),i.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER,null),i.deleteBuffer(a);let d=0;const u=new Float32Array(c.buffer);for(let h=0;h{if(s){const a=new Int32Array(s);for(let l=0;l0){n.bind();for(const r of s)r(n)}return n}}function PV(i,e){const t=new Set;for(const n of e){const s=new RegExp(`(?:^|[^a-zA-Z0-9_])${n}[^a-zA-Z0-9_])`);i.match(s)!==null&&t.add(n)}return t}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function dr(){return new _.B0(void 0)}function Co(i){return new _.DN(i,f.zr)}function wo(i,e,t){const n=new Map,{parameters:s,fallbackParameters:r,shaderError:o,encodeParameters:a=v=>v,extraParameters:l=(0,_.XZ)(void 0),encodeExtraParameters:c=v=>v,getContextKey:d,defineShader:u}=t;o!==void 0&&(o.value=void 0);const{encodeContext:h=d}=t,p=(0,f.JB)(t.memoizeKey);function m(v,y,S){const w=JSON.stringify({id:p,context:h(v),parameters:a(y),extraParameters:c(S)});return e.memoize.get(w,()=>{const b=new fn(e);return u(b,v,y,S),b.build()})}function g(v){const y=d(v);let S=n.get(y);S===void 0&&(S={parametersGeneration:-1,extraParametersGeneration:-1,shader:null,fallback:!1,parameters:s.value,extraParameters:l.value},n.set(y,S));const w=s.changed.count,b=l.changed.count;if(w===S.parametersGeneration&&b===S.extraParametersGeneration)return S;const x=S.parameters=s.value,E=S.extraParameters=l.value,D=S.shader;S.parametersGeneration=w,S.extraParametersGeneration=b;let I=null;try{I=m(v,x,E),S.fallback=!1,r!==void 0&&(r.value=x),o!==void 0&&(o.value=null)}catch(L){if(o!==void 0&&(o.value=L),r!==void 0)try{const N=r.value;I=m(v,N,E),S.parameters=N,S.fallback=!0}catch{}}return D!==null&&D.dispose(),S.shader=I,S}return i.registerDisposer(()=>{for(const v of n.values()){const{shader:y}=v;y!==null&&y.dispose()}}),g}function Ai(i,e,t){return wo(i,e,{...t,getContextKey:n=>n,encodeContext:n=>xt(n),defineShader:(n,s,r,o)=>(n.require(s),t.defineShader(n,r,o))})}function ms(i,e=1,t=0){return` +#line ${t} ${e} +`+i}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class At{constructor(e,t=WebGL2RenderingContext.ARRAY_BUFFER){this.gl=e,this.bufferType=t,this.gl=e,this.buffer=e.createBuffer()}bind(){this.gl.bindBuffer(this.bufferType,this.buffer)}bindToVertexAttrib(e,t,n=WebGL2RenderingContext.FLOAT,s=!1,r=0,o=0){this.bind(),this.gl.enableVertexAttribArray(e),this.gl.vertexAttribPointer(e,t,n,s,r,o)}bindToVertexAttribI(e,t,n=WebGL2RenderingContext.UNSIGNED_INT,s=0,r=0){this.bind(),this.gl.enableVertexAttribArray(e),this.gl.vertexAttribIPointer(e,t,n,s,r)}setData(e,t=WebGL2RenderingContext.STATIC_DRAW){const n=this.gl;this.bind(),n.bufferData(this.bufferType,e,t)}dispose(){this.gl.deleteBuffer(this.buffer),this.buffer=void 0,this.gl=void 0}static fromData(e,t,n,s){const r=new At(e,n);return r.setData(t,s),r}}function ci(i,e,t,...n){return i.memoize.get((0,f.JB)({id:"getMemoizedBuffer",getter:xt(t),args:n}),()=>{const s=new T.fL(At.fromData(i,t(...n),e,WebGL2RenderingContext.STATIC_DRAW));return s.registerDisposer(s.value),s})}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function gw(i=-1,e=-1,t=1,n=1,s=1,r=1){return(0,F.CS)(new Float32Array([i,e,i,n,t,n,t,e]),2,s,r)}function AV(i=-1,e=-1,t=-1,n=1,s=1,r=1,o=1,a=1){return tile2dArray(new Float32Array([i,e,t,n,e,t,i,s,t,n,s,t,i,e,r,n,e,r,i,s,r,n,s,r]),3,o,a)}function ur(i,e=-1,t=-1,n=1,s=1,r=1,o=1){return ci(i,WebGL2RenderingContext.ARRAY_BUFFER,gw,e,t,n,s,r,o).value}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function di(i){i.texParameteri(WebGL2RenderingContext.TEXTURE_2D,WebGL2RenderingContext.TEXTURE_MIN_FILTER,WebGL2RenderingContext.NEAREST),i.texParameteri(WebGL2RenderingContext.TEXTURE_2D,WebGL2RenderingContext.TEXTURE_MAG_FILTER,WebGL2RenderingContext.NEAREST),i.texParameteri(WebGL2RenderingContext.TEXTURE_2D,WebGL2RenderingContext.TEXTURE_WRAP_S,WebGL2RenderingContext.CLAMP_TO_EDGE),i.texParameteri(WebGL2RenderingContext.TEXTURE_2D,WebGL2RenderingContext.TEXTURE_WRAP_T,WebGL2RenderingContext.CLAMP_TO_EDGE)}function mw(i){i.texParameteri(WebGL2RenderingContext.TEXTURE_3D,WebGL2RenderingContext.TEXTURE_MIN_FILTER,WebGL2RenderingContext.NEAREST),i.texParameteri(WebGL2RenderingContext.TEXTURE_3D,WebGL2RenderingContext.TEXTURE_MAG_FILTER,WebGL2RenderingContext.NEAREST),i.texParameteri(WebGL2RenderingContext.TEXTURE_3D,WebGL2RenderingContext.TEXTURE_WRAP_S,WebGL2RenderingContext.CLAMP_TO_EDGE),i.texParameteri(WebGL2RenderingContext.TEXTURE_3D,WebGL2RenderingContext.TEXTURE_WRAP_T,WebGL2RenderingContext.CLAMP_TO_EDGE),i.texParameteri(WebGL2RenderingContext.TEXTURE_3D,WebGL2RenderingContext.TEXTURE_WRAP_R,WebGL2RenderingContext.CLAMP_TO_EDGE)}function vw(i,e,t,n,s=WebGL2RenderingContext.RGBA8,r=WebGL2RenderingContext.RGBA,o=WebGL2RenderingContext.UNSIGNED_BYTE){i.activeTexture(WebGL2RenderingContext.TEXTURE0+i.tempTextureUnit),i.bindTexture(WebGL2RenderingContext.TEXTURE_2D,e),di(i),i.texImage2D(WebGL2RenderingContext.TEXTURE_2D,0,s,t,n,0,r,o,null),i.bindTexture(WebGL2RenderingContext.TEXTURE_2D,null)}function yw(i,e,t){i.activeTexture(WebGL2RenderingContext.TEXTURE0+i.tempTextureUnit),i.bindTexture(WebGL2RenderingContext.TEXTURE_2D,e),i.texParameteri(WebGL2RenderingContext.TEXTURE_2D,WebGL2RenderingContext.TEXTURE_MIN_FILTER,WebGL2RenderingContext.LINEAR),i.texParameteri(WebGL2RenderingContext.TEXTURE_2D,WebGL2RenderingContext.TEXTURE_MAG_FILTER,WebGL2RenderingContext.LINEAR),i.texParameteri(WebGL2RenderingContext.TEXTURE_2D,WebGL2RenderingContext.TEXTURE_WRAP_S,WebGL2RenderingContext.CLAMP_TO_EDGE),i.texParameteri(WebGL2RenderingContext.TEXTURE_2D,WebGL2RenderingContext.TEXTURE_WRAP_T,WebGL2RenderingContext.CLAMP_TO_EDGE),i.pixelStorei(WebGL2RenderingContext.UNPACK_FLIP_Y_WEBGL,1),i.pixelStorei(WebGL2RenderingContext.UNPACK_ALIGNMENT,4),i.texImage2D(WebGL2RenderingContext.TEXTURE_2D,0,WebGL2RenderingContext.RGBA8,WebGL2RenderingContext.RGBA,WebGL2RenderingContext.UNSIGNED_BYTE,t),i.pixelStorei(WebGL2RenderingContext.UNPACK_FLIP_Y_WEBGL,0),i.bindTexture(WebGL2RenderingContext.TEXTURE_2D,null)}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function lc(i){i.addOutputBuffer("vec4","v4f_fragColor",null),i.setFragmentMain("v4f_fragColor = getValue0();")}function xp(i,e=lc,t=1){return i.memoize.get(`elementWiseTextureShader:${t}:${xt(e)}`,()=>{const n=new fn(i);n.addVarying("vec2","vTexCoord"),n.addUniform("sampler2D","uSampler",t),n.addInitializer(s=>{const r=[];for(let o=0;o{const e=new fn(i);return e.addVarying("vec4","vColor"),e.addOutputBuffer("vec4","v4f_fragColor",null),e.setFragmentMain("v4f_fragColor = vColor;"),e.addAttribute("vec4","aVertexPosition"),e.addAttribute("vec4","aColor"),e.addUniform("mat4","uProjectionMatrix"),e.setVertexMain("vColor = aColor; gl_Position = uProjectionMatrix * aVertexPosition;"),e.build()})}function NV(i){return i.memoize.get("trivialUniformColorShader",()=>{const e=new ShaderBuilder(i);return e.addUniform("mat4","uProjectionMatrix"),e.addAttribute("vec4","aVertexPosition"),e.addUniform("vec4","uColor"),e.addOutputBuffer("vec4","v4f_fragColor",null),e.setFragmentMain("v4f_fragColor = uColor;"),e.setVertexMain("gl_Position = uProjectionMatrix * aVertexPosition;"),e.build()})}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Ep extends T.O8{constructor(){super(...arguments),this.width=Number.NaN,this.height=Number.NaN}hasSize(e,t){return this.width===e&&this.height===t}resize(e,t){this.hasSize(e,t)||(this.width=e,this.height=t,this.performResize())}}class bw extends Ep{constructor(e,t){super(),this.gl=e,this.internalformat=t,this.renderbuffer=null,this.renderbuffer=e.createRenderbuffer()}performResize(){const{gl:e}=this;e.bindRenderbuffer(e.RENDERBUFFER,this.renderbuffer),e.renderbufferStorage(e.RENDERBUFFER,this.internalformat,this.width,this.height),e.bindRenderbuffer(e.RENDERBUFFER,null)}disposed(){this.gl.deleteRenderbuffer(this.renderbuffer)}attachToFramebuffer(e){const{gl:t}=this;t.framebufferRenderbuffer(t.FRAMEBUFFER,e,t.RENDERBUFFER,this.renderbuffer)}}class Cw extends bw{constructor(e,t=!1){super(e,t?e.DEPTH_STENCIL:e.DEPTH_COMPONENT16),this.gl=e,this.includeStencilBuffer=t}attachToFramebuffer(){const{gl:e}=this;super.attachToFramebuffer(this.includeStencilBuffer?e.DEPTH_STENCIL_ATTACHMENT:e.DEPTH_ATTACHMENT)}}class xo extends Cw{constructor(e){super(e,!0)}}const OV=null;class ww extends T.O8{constructor(e){super(),this.gl=e,this.framebuffer=this.gl.createFramebuffer()}disposed(){const{gl:e}=this;e.deleteFramebuffer(this.framebuffer)}bind(){const{gl:e}=this;e.bindFramebuffer(e.FRAMEBUFFER,this.framebuffer)}unbind(){const{gl:e}=this;e.bindFramebuffer(e.FRAMEBUFFER,null)}}class gn extends Ep{constructor(e,t,n,s){super(),this.gl=e,this.internalFormat=t,this.format=n,this.dataType=s,this.texture=e.createTexture()}performResize(){vw(this.gl,this.texture,this.width,this.height,this.internalFormat,this.format,this.dataType)}disposed(){this.gl.deleteTexture(this.texture)}attachToFramebuffer(e){const{gl:t}=this;t.framebufferTexture2D(t.FRAMEBUFFER,e,t.TEXTURE_2D,this.texture,0)}}class xw extends gn{constructor(e,t=WebGL2RenderingContext.DEPTH_COMPONENT16,n=WebGL2RenderingContext.DEPTH_COMPONENT,s=WebGL2RenderingContext.UNSIGNED_SHORT){super(e,t,n,s)}attachToFramebuffer(){super.attachToFramebuffer(this.format===WebGL2RenderingContext.DEPTH_COMPONENT?WebGL2RenderingContext.DEPTH_ATTACHMENT:WebGL2RenderingContext.DEPTH_STENCIL_ATTACHMENT)}}function vs(i,e,t=WebGL2RenderingContext.RGBA8,n=WebGL2RenderingContext.RGBA,s=WebGL2RenderingContext.UNSIGNED_BYTE){const r=new Array;for(let o=0;o{this.registerDisposer(a),o[l]=e.COLOR_ATTACHMENT0+l})}hasSize(e,t){return this.width===e&&this.height===t}bind(e,t){this.width=e,this.height=t,this.framebuffer.bind();const{gl:n,depthBuffer:s}=this;s!==void 0?(s.resize(e,t),s.attachToFramebuffer()):n.framebufferRenderbuffer(WebGL2RenderingContext.FRAMEBUFFER,WebGL2RenderingContext.DEPTH_STENCIL_ATTACHMENT,WebGL2RenderingContext.RENDERBUFFER,null),this.colorBuffers.forEach((r,o)=>{r.resize(e,t),r.attachToFramebuffer(n.COLOR_ATTACHMENT0+o)}),n.drawBuffers(this.fullAttachmentList),this.verifyAttachment(),n.viewport(0,0,e,t)}bindSingle(e){const{gl:t}=this;this.framebuffer.bind(),e!==0&&t.framebufferTexture2D(t.FRAMEBUFFER,t.COLOR_ATTACHMENT0+e,t.TEXTURE_2D,null,0),t.bindTexture(t.TEXTURE_2D,null),this.colorBuffers[e].attachToFramebuffer(t.COLOR_ATTACHMENT0),t.drawBuffers(this.singleAttachmentList)}unbind(){this.framebuffer.unbind()}readPixelFloat32IntoBuffer(e,t,n,s,r=1,o=1){const{gl:a}=this;try{this.bindSingle(e),a.readPixels(t,n,r,o,WebGL2RenderingContext.RGBA,WebGL2RenderingContext.FLOAT,s)}finally{this.framebuffer.unbind()}}verifyAttachment(){if(this.attachmentVerified)return;const{gl:e}=this,t=e.checkFramebufferStatus(e.FRAMEBUFFER);if(t!==e.FRAMEBUFFER_COMPLETE)throw new Error(`Framebuffer configuration not supported: ${t}`);this.attachmentVerified=!0}}class Dn extends T.O8{constructor(e,t){super(),this.gl=e,this.shader=t,this.copyVertexPositionsBuffer=ur(this.gl),this.copyTexCoordsBuffer=ur(this.gl,0,0,1,1),this.registerDisposer(t)}draw(...e){const{gl:t,shader:n}=this;n.bind();const s=e.length;for(let a=0;anew Dn(e,xp(e,t,n)))}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Ew=` +float mixLinear(float x, float y, float a) { return mix(x, y, a); } +`,Tw=` +vec3 hueToRgb(float hue) { + float hue6 = hue * 6.0; + float r = abs(hue6 - 3.0) - 1.0; + float g = 2.0 - abs(hue6 - 2.0); + float b = 2.0 - abs(hue6 - 4.0); + return clamp(vec3(r, g, b), 0.0, 1.0); +} +vec3 hsvToRgb(vec3 c) { + vec3 hueRgb = hueToRgb(c.x); + return c.z * ((hueRgb - 1.0) * c.y + 1.0); +} +`,gt=` +struct uint64_t { + highp uvec2 value; +}; +struct uint64x2_t { + highp uvec4 value; +}; +uint64_t mixLinear(uint64_t x, uint64_t y, float a) { + return x; +} +uint64_t toUint64(uint64_t x) { return x; } +`,Dw=[gt,` +uint64_t unpackUint64leFromUint32(highp uvec2 x) { + uint64_t result; + result.value = x; + return result; +} +uint64x2_t unpackUint64leFromUint32(highp uvec4 x) { + uint64x2_t result; + result.value = x; + return result; +} +`],Tp=[gt,` +bool equals(uint64_t a, uint64_t b) { + return a.value == b.value; +} +`],Eo=[gt,` +bool compareLessThan(uint64_t a, uint64_t b) { + return (a.value[1] < b.value[1])|| + (a.value[1] == b.value[1] && a.value[0] < b.value[0]); +} +`],Dp=[gt,` +uint64_t subtract(uint64_t a, uint64_t b) { + if (a.value[0] < b.value[0]) { + --a.value[1]; + } + a.value -= b.value; + return a; +} +`],Iw=[[gt,` +uint64_t add(uint64_t a, uint64_t b) { + a.value[0] += b.value[0]; + if (a.value[0] < b.value[0]) { + ++a.value[1]; + } + a.value[1] += b.value[1]; + return a; +} +`],Eo,` +uint64_t addSaturate(uint64_t a, uint64_t b) { + a = add(a, b); + if (compareLessThan(a, b)) { + a.value = uvec2(0xffffffffu, 0xffffffffu); + } + return a; +} +`],Lw=[Dp,Eo,` +uint64_t subtractSaturate(uint64_t a, uint64_t b) { + b = subtract(a, b); + if (compareLessThan(a, b)) { + b.value = uvec2(0u, 0u); + } + return b; +} +`],Ip=[gt,` +uint64_t shiftRight(uint64_t a, int shift) { + if (shift >= 32) { + return uint64_t(uvec2(a.value[1] >> (shift - 32), 0u)); + } else if (shift == 0) { + return a; + } else { + return uint64_t(uvec2((a.value[0] >> shift) | (a.value[1] << (32 - shift)), a.value[1] >> shift)); + } +} +`],Rw=[gt,` +uint64_t shiftLeft(uint64_t a, int shift) { + if (shift >= 32) { + return uint64_t(uvec2(0u, a.value[0] << (shift - 32))); + } else if (shift == 0) { + return a; + } else { + return uint64_t(uvec2(a.value[0] << shift, (a.value[1] << shift) | (a.value[0] >> (32 - shift)))); + } +} +`],Lp=[gt,` +struct uint8_t { + highp uint value; +}; +struct uint8x2_t { + highp uvec2 value; +}; +struct uint8x3_t { + highp uvec3 value; +}; +struct uint8x4_t { + highp uvec4 value; +}; +uint8_t mixLinear(uint8_t x, uint8_t y, highp float a) { + return uint8_t(uint(round(mix(float(x.value), float(y.value), a)))); +} +highp uint toRaw(uint8_t x) { return x.value; } +highp float toNormalized(uint8_t x) { return float(x.value) / 255.0; } +highp uvec2 toRaw(uint8x2_t x) { return x.value; } +highp vec2 toNormalized(uint8x2_t x) { return vec2(x.value) / 255.0; } +highp uvec3 toRaw(uint8x3_t x) { return x.value; } +vec3 toNormalized(uint8x3_t x) { return vec3(x.value) / 255.0; } +highp uvec4 toRaw(uint8x4_t x) { return x.value; } +vec4 toNormalized(uint8x4_t x) { return vec4(x.value) / 255.0; } +uint64_t toUint64(uint8_t x) { + uint64_t result; + result.value[0] = x.value; + result.value[1] = 0u; + return result; +} +uint8_t uint8FromFloat(highp float x) { + return uint8_t(uint(clamp(x, 0.0, 255.0))); +} +`],Rp=[gt,` +struct int8_t { + highp int value; +}; +struct int8x2_t { + highp ivec2 value; +}; +struct int8x3_t { + highp ivec3 value; +}; +struct int8x4_t { + highp ivec4 value; +}; +int8_t mixLinear(int8_t x, int8_t y, highp float a) { + return int8_t(int(round(mix(float(x.value), float(y.value), a)))); +} +highp int toRaw(int8_t x) { return x.value; } +highp ivec2 toRaw(int8x2_t x) { return x.value; } +highp ivec3 toRaw(int8x3_t x) { return x.value; } +highp ivec4 toRaw(int8x4_t x) { return x.value; } +uint64_t toUint64(int8_t x) { + uint64_t result; + result.value[0] = uint(x.value); + result.value[1] = uint(x.value >> 31); + return result; +} +int8_t int8FromFloat(highp float x) { + return int8_t(int(clamp(x, -128.0, 127.0))); +} +`],cc=` +highp float toRaw(highp float x) { return x; } +highp float toNormalized(highp float x) { return x; } +vec2 toRaw(vec2 x) { return x; } +vec2 toNormalized(vec2 x) { return x; } +vec3 toRaw(vec3 x) { return x; } +vec3 toNormalized(vec3 x) { return x; } +vec4 toRaw(vec4 x) { return x; } +vec4 toNormalized(vec4 x) { return x; } +`,kp=[gt,` +struct uint16_t { + highp uint value; +}; +struct uint16x2_t { + highp uvec2 value; +}; +uint16_t mixLinear(uint16_t x, uint16_t y, highp float a) { + return uint16_t(uint(round(mix(float(x.value), float(y.value), a)))); +} +highp uint toRaw(uint16_t x) { return x.value; } +highp float toNormalized(uint16_t x) { return float(toRaw(x)) / 65535.0; } +highp uvec2 toRaw(uint16x2_t x) { return x.value; } +highp vec2 toNormalized(uint16x2_t x) { return vec2(toRaw(x)) / 65535.0; } +uint64_t toUint64(uint16_t x) { + uint64_t result; + result.value[0] = x.value; + result.value[1] = 0u; + return result; +} +uint16_t uint16FromFloat(highp float x) { + return uint16_t(uint(clamp(x, 0.0, 65535.0))); +} +`],Pp=[gt,` +struct int16_t { + highp int value; +}; +struct int16x2_t { + highp ivec2 value; +}; +int16_t mixLinear(int16_t x, int16_t y, highp float a) { + return int16_t(int(round(mix(float(x.value), float(y.value), a)))); +} +highp int toRaw(int16_t x) { return x.value; } +highp ivec2 toRaw(int16x2_t x) { return x.value; } +uint64_t toUint64(int16_t x) { + uint64_t result; + result.value[0] = uint(x.value); + result.value[1] = uint(x.value >> 31); + return result; +} +int16_t int16FromFloat(highp float x) { + return int16_t(int(clamp(x, -32768.0, 32767.0))); +} +`],To=[gt,` +struct uint32_t { + highp uint value; +}; +uint32_t mixLinear(uint32_t x, uint32_t y, highp float a) { + return uint32_t(uint(round(mix(float(x.value), float(y.value), a)))); +} +highp float toNormalized(uint32_t x) { return float(x.value) / 4294967295.0; } +highp uint toRaw(uint32_t x) { return x.value; } +uint64_t toUint64(uint32_t x) { + uint64_t result; + result.value[0] = x.value; + result.value[1] = 0u; + return result; +} +uint32_t uint32FromFloat(highp float x) { + return uint32_t(uint(clamp(x, 0.0, 4294967295.0))); +} +`],Ap=[gt,` +struct int32_t { + highp int value; +}; +int32_t mixLinear(int32_t x, int32_t y, highp float a) { + return int32_t(int(round(mix(float(x.value), float(y.value), a)))); +} +highp int toRaw(int32_t x) { return x.value; } +uint64_t toUint64(int32_t x) { + uint64_t result; + result.value[0] = uint(x.value); + result.value[1] = uint(x.value >> 31); + return result; +} +int32_t int32FromFloat(highp float x) { + return int32_t(int(clamp(x, 2147483648.0, 2147483647.0))); +} +`],kw=` +highp int getFortranOrderIndex(ivec3 subscripts, ivec3 size) { + return subscripts.x + size.x * (subscripts.y + size.y * subscripts.z); +} +`,Pw=` +highp uint log2Exact(highp uint i) { + highp uint r; + r = uint((i & 0xAAAAAAAAu) != 0u); + r |= uint((i & 0xFFFF0000u) != 0u) << 4; + r |= uint((i & 0xFF00FF00u) != 0u) << 3; + r |= uint((i & 0xF0F0F0F0u) != 0u) << 2; + r |= uint((i & 0xCCCCCCCCu) != 0u) << 1; + return r; +} +`,Aw=` +bool clipLineToDepthRange(inout highp vec4 a, inout highp vec4 b) { + highp float tmin = 0.0, tmax = 1.0; + highp float k1 = b.w - a.w + a.z - b.z; + highp float k2 = a.w - b.w + a.z - b.z; + highp float q1 = (a.z - a.w) / k1; + highp float q2 = (a.z + a.w) / k2; + if (k1 > 0.0) tmin = max(tmin, q1); + else if (k1 < 0.0) tmax = min(tmax, q1); + if (k2 > 0.0) tmax = min(tmax, q2); + else if (k2 < 0.0) tmin = max(tmin, q2); + if (tmin <= tmax) { + highp vec4 tempA = a; + highp vec4 tempB = b; + a = mix(tempA, tempB, tmin); + b = mix(tempA, tempB, tmax); + return true; + } + return false; +} +`,Mp=` +highp float simpleFloatHash(highp vec2 co) { + return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453); +} +`,Mw=` +highp uint shiftLeftSaturate(highp uint x, int shiftAmount) { + highp uint result = x << shiftAmount; + if ((result >> shiftAmount) != x) return 0xffffffffu; + return result; +} +`,dc=` +highp uint addSaturate(highp uint x, highp uint y) { + highp uint result = x + y; + if (result < x) return 0xffffffffu; + return result; +} +`,Nw=` +highp uint subtractSaturate(highp uint x, highp uint y) { + highp uint result = x - y; + if (result > x) return 0u; + return result; +} +`,Ow=[dc,` +highp int addSaturate(highp int x, highp uint y) { + if (x >= 0) { + return int(min(addSaturate(y, uint(x)), 0x7fffffffu)); + } else if (y >= uint(-x)) { + return int(min(y - uint(-x), 0x7fffffffu)); + } else { + return -int(min(uint(-x) - y, 0x80000000u)); + } +} +`],_w=[dc,` +highp int subtractSaturate(highp int x, highp uint y) { + if (x < 0) { + return -int(min(addSaturate(uint(-x), uint(y)), 0x80000000u)); + } else if (uint(x) >= y) { + return x - int(y); + } else { + return -int(min(y - uint(x), 0x80000000u)); + } +} +`];function yt(i,e=1){switch(i){case R.FLOAT32:if(e===1)return"float";if(e>1&&e<=4)return`vec${e}`;break;case R.UINT8:case R.INT8:case R.UINT16:case R.INT16:case R.UINT32:case R.INT32:case R.UINT64:{const t=ae[i]?"":"u",n=B[i]*8;if(e===1)return`${t}int${n}_t`;if(e>1&&e*n<=32)return`${t}int${n}x${e}_t`;break}}throw new Error(`No shader type for ${R[i]}[${e}].`)}const ys={[R.UINT8]:Lp,[R.INT8]:Rp,[R.UINT16]:kp,[R.INT16]:Pp,[R.UINT32]:To,[R.INT32]:Ap,[R.UINT64]:gt,[R.FLOAT32]:cc};function Vw(i,e){return e===1?i:i==="float"?`vec${e}`:`${i[0]}vec${e}`}const Bw={[WebGL2RenderingContext.UNSIGNED_BYTE]:1,[WebGL2RenderingContext.BYTE]:1,[WebGL2RenderingContext.UNSIGNED_SHORT]:2,[WebGL2RenderingContext.SHORT]:2,[WebGL2RenderingContext.FLOAT]:4,[WebGL2RenderingContext.INT]:4,[WebGL2RenderingContext.UNSIGNED_INT]:4};function Do(i,e,t,n,s,r,o=1){let a=0,l=r*o;for(;l>0;){const u=Math.min(4,l),h=Vw(e,u);l-=u,i.addAttribute("highp "+h,`a${s}${a}`),++a}l=r*o;let c="";for(let u=0;u{const h=[];for(let p=0;p{const t=new fn(this.gl);return t.addOutputBuffer("vec4","outputValue",0),t.addAttribute("float","aInput1"),t.addTextureSampler("sampler2D","uDataSampler",Op),t.addTextureSampler("sampler2D","uDepthSampler",_p),t.addVertexCode(Mp),t.setVertexMain(` +float uRandomSeed = 0.0; +vec2 p = vec2(simpleFloatHash(vec2(aInput1 + float(gl_VertexID), uRandomSeed + float(gl_InstanceID))), + simpleFloatHash(vec2(aInput1 + float(gl_VertexID) + 10.0, 5.0 + uRandomSeed + float(gl_InstanceID)))); +float dataValue = texture(uDataSampler, p).x; +float stencilValue = texture(uDepthSampler, p).x; +if (stencilValue == 1.0) { + gl_Position = vec4(2.0, 2.0, 2.0, 1.0); +} else { + gl_Position = vec4(2.0 * (dataValue * 255.0 + 0.5) / 256.0 - 1.0, 0.0, 0.0, 1.0); +} +gl_PointSize = 1.0; +`),t.setFragmentMain(` +outputValue = vec4(1.0, 1.0, 1.0, 1.0); +`),t.build()})()),this.inputIndexBuffer=this.registerDisposer(ci(this.gl,WebGL2RenderingContext.ARRAY_BUFFER,()=>new Uint8Array(uc)))}static get(e){return e.memoize.get("textureHistogramGeneration",()=>new hc(e))}compute(e,t,n,s,r){const{gl:o}=this,{shader:a}=this,l=s.getFramebuffers(o);a.bind(),o.enable(WebGL2RenderingContext.BLEND),o.disable(WebGL2RenderingContext.SCISSOR_TEST),o.disable(WebGL2RenderingContext.DEPTH_TEST),o.blendFunc(WebGL2RenderingContext.ONE,WebGL2RenderingContext.ONE),this.inputIndexBuffer.value.bindToVertexAttrib(a.attribute("aInput1"),1,WebGL2RenderingContext.UNSIGNED_BYTE,!0);const c=a.textureUnit(Op),d=a.textureUnit(_p);o.activeTexture(WebGL2RenderingContext.TEXTURE0+d),o.bindTexture(WebGL2RenderingContext.TEXTURE_2D,t),di(o),o.activeTexture(WebGL2RenderingContext.TEXTURE0+c);const u=s.frameNumber;s.frameNumber=r;for(let h=0;h= p.offset) { + x = uint(v - p.offset); + } else { + x = uint(p.offset - v); + p.multiplier = -p.multiplier; + } + x >>= p.shift; + return float(x) * p.multiplier; +} +float computeInvlerp(${e} inputValue, ${n} p) { + return computeInvlerp(toRaw(inputValue), p); +} +`]}const $w={[R.UINT8]:Io(R.UINT8),[R.INT8]:Io(R.INT8),[R.UINT16]:Io(R.UINT16),[R.INT16]:Io(R.INT16),[R.FLOAT32]:Vp,[R.UINT32]:Bp(R.UINT32),[R.INT32]:Bp(R.INT32),[R.UINT64]:[gt,Eo,Dp,Ip,hr[R.UINT64],` +float computeInvlerp(uint64_t inputValue, Uint64LerpParameters p) { + if (compareLessThan(inputValue, p.offset)) { + inputValue = subtract(p.offset, inputValue); + p.multiplier = -p.multiplier; + } else { + inputValue = subtract(inputValue, p.offset); + } + uint shifted = shiftRight(inputValue, p.shift).value[0]; + return float(shifted) * p.multiplier; +} +`]};function pr(i){let t=` +${yt(i)} computeLerp(float inputValue, vec2 p) { + inputValue = inputValue / p[1] + p[0]; +`;return i===R.FLOAT32?t+=`return inputValue; +`:t+=`return ${R[i].toLowerCase()}FromFloat(round(inputValue)); +`,t+=` +} +`,[ys[i],t]}function Fp(i){const e=yt(i),t=pc[i];return[ys[i],hr[i],Mw,i===R.UINT32?dc:Ow,i===R.UINT32?Nw:_w,` +${e} computeLerp(float inputValue, ${t} p) { + inputValue = inputValue / p.multiplier; + uint x = uint(clamp(round(abs(inputValue)), 0.0, 4294967295.0)); + uint xShifted = shiftLeftSaturate(x, p.shift); + if (inputValue >= 0.0) { + return ${e}(addSaturate(p.offset, xShifted)); + } else { + return ${e}(subtractSaturate(p.offset, xShifted)); + } +} +`]}const Gw={[R.UINT8]:pr(R.UINT8),[R.INT8]:pr(R.INT8),[R.UINT16]:pr(R.UINT16),[R.INT16]:pr(R.INT16),[R.FLOAT32]:pr(R.FLOAT32),[R.UINT32]:Fp(R.UINT32),[R.INT32]:Fp(R.INT32),[R.UINT64]:[gt,Eo,Tp,Iw,Lw,Ip,Rw,hr[R.UINT64],` +uint64_t computeLerp(float inputValue, Uint64LerpParameters p) { + inputValue = inputValue / p.multiplier; + uint64_t x = uint64_t(uvec2(uint(clamp(round(abs(inputValue)), 0.0, 4294967295.0)), 0u)); + uint64_t shifted = shiftLeft(x, p.shift); + if (!equals(shiftRight(shifted, p.shift), x)) { + return uint64_t(uvec2(0xffffffffu, 0xffffffffu)); + } + if (inputValue >= 0.0) { + return addSaturate(p.offset, shifted); + } else { + return subtractSaturate(p.offset, shifted); + } +} +`]};function Up(i,e,t){const n=`uLerpParams_${e}`,s=`uLerpBounds_${e}`,r=`uLerpScalar_${e}`;let o="";switch(t){case R.INT8:case R.UINT8:case R.INT16:case R.UINT16:case R.FLOAT32:i.addUniform("vec2",n);break;case R.INT32:case R.UINT32:{const a=pc[t];i.addUniform(`${t===R.INT32?"i":"u"}vec2`,s),i.addUniform("float",r),o+=` +#define ${n} ${a}(${s}[0], int(${s}[1]), ${r}) +`;break}case R.UINT64:{i.addUniform("uvec3",s),i.addUniform("float",r),o+=` +#define ${n} Uint64LerpParameters(uint64_t(${s}.xy), int(${s}[2]), ${r}) +`;break}}return[hr[t],o]}function Ss(i,e,t,n=!1){const s=yt(t);let r=` +float ${e}(${s} inputValue) { + float v = computeInvlerp(inputValue, uLerpParams_${e}); + ${n?"v = clamp(v, 0.0, 1.0);":""} + defaultMaxProjectionIntensity = v; + return v; +} +`;if(t!==R.UINT64&&t!==R.FLOAT32){const o=ae[t]?"int":"uint";r+=` +float ${e}(${o} inputValue) { + return ${e}(${s}(inputValue)); +} +`}return[ys[t],Up(i,e,t),$w[t],r]}function zw(i,e,t){return[ys[t],Up(i,e,t),Gw[t],` +${yt(t)} ${e}(float inputValue) { + return computeLerp(inputValue, uLerpParams_${e}); +} +`]}const Mi=new P.R;function Ni(i,e,t,n){const{gl:s}=i;switch(t){case R.INT8:case R.UINT8:case R.INT16:case R.UINT16:case R.FLOAT32:s.uniform2f(i.uniform(`uLerpParams_${e}`),n[0],1/(n[1]-n[0]));break;case R.INT32:case R.UINT32:{const r=n[0],o=n[1]-r,a=Math.max(0,Math.ceil(Math.log2(Math.abs(o)))-24),l=2**a/o,c=i.uniform(`uLerpBounds_${e}`);t===R.UINT32?s.uniform2ui(c,r,a):s.uniform2i(c,r,a),s.uniform1f(i.uniform(`uLerpScalar_${e}`),l);break}case R.UINT64:{const r=n[0],o=n[1];P.R.absDifference(Mi,o,r);const a=Mi.high>0?32+Math.ceil(Math.log2(Mi.high)):Math.ceil(Math.log2(Mi.low)),l=Math.max(0,a-24);P.R.rshift(Mi,Mi,l);let c=1/Mi.low;P.R.compare(r,o)>0&&(c*=-1);const d=i.uniform(`uLerpBounds_${e}`);s.uniform3ui(d,r.low,r.high,l),s.uniform1f(i.uniform(`uLerpScalar_${e}`),c)}}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Mt(i,e,t){(0,f.MM)(i,e,n=>t.restoreState(n))}class fr extends T.O8{constructor(){super(...arguments),this.children=new Map,this.changed=new j.IY}add(e,t){const{children:n}=this;if(n.has(e))throw new Error(`Key ${JSON.stringify(e)} already registered.`);return this.children.set(e,t),t.changed.add(this.changed.dispatch),this.changed.dispatch(),()=>{this.remove(e)}}remove(e){const{children:t}=this;if(t.has(e))throw new Error(`Key ${JSON.stringify(e)} not registered.`);const n=t.get(e);this.children.delete(e),n.changed.remove(this.changed.dispatch),this.changed.dispatch()}disposed(){const{changed:e}=this;for(const t of this.children.values())t.changed.remove(e.dispatch);this.children=void 0,super.disposed()}toJSON(){const e=this.baseJSON();for(const[t,n]of this.children)e[t]=n.toJSON();return e}baseJSON(){return{}}reset(){for(const e of this.children.values())e.reset()}restoreState(e){(0,f.Rf)(e);for(const[t,n]of this.children)try{if(Object.prototype.hasOwnProperty.call(e,t)){const s=e[t];if(s===void 0)continue;n.restoreState(s)}}catch(s){throw new Error(`Error restoring property ${JSON.stringify(t)}: ${s.message}`)}}}class VV extends fr{constructor(){super(...arguments),this.lastState={}}restoreState(e){(0,f.Rf)(e),this.lastState=e,super.restoreState(e)}reset(){this.lastState={},super.reset()}baseJSON(){const e=Object.assign(super.baseJSON(),this.lastState);for(const t of this.children.keys())delete e[t];return e}toJSON(){const e=super.toJSON();return this.lastState=e,e}add(e,t){const n=super.add(e,t),s=this.lastState[e];return s!==void 0&&(t.reset(),t.restoreState(s)),n}}const $p=new WeakMap;function Lo(i){let e=$p.get(i);const t=i.changed.count;if(e!==void 0&&e.generation===t)return e;let n;if(i instanceof fr){n=i.baseJSON();for(const[s,r]of i.children)n[s]=Lo(r).value}else n=i.toJSON();return e===void 0?(e={generation:t,value:n},$p.set(i,e)):(e.generation=t,e.value=n),e}var Oi=G(6703);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var Ro=(i=>(i[i.LINKED=0]="LINKED",i[i.RELATIVE=1]="RELATIVE",i[i.UNLINKED=2]="UNLINKED",i))(Ro||{}),Gp=(i=>(i[i.LINKED=0]="LINKED",i[i.UNLINKED=2]="UNLINKED",i))(Gp||{});class Ww extends Oi.F{constructor(e=0){super(Ro,e)}}class BV extends Oi.F{constructor(e=0){super(Gp,e)}}const ko=C.eR.create(),zp=C.Yu.create();function gr(i,e,t,n){let s=!1;const r=!1;let o;i.registerDisposer(e);const a=()=>{if(!r){switch(s=!0,t.value){case 2:if(n.isValid(i))break;case 0:n.assign(i,e);break;case 1:n.add(i,e,o);break}s=!1}},l=()=>{if(!s)switch(t.value){case 2:break;case 0:n.assign(e,i);break;case 1:n.subtract(e,i,o);break}};let c=2;const d=()=>{const u=t.value;if(u!==c)switch(u){case 2:o=void 0;break;case 0:o=void 0,n.assign(i,e);break;case 1:o=n.difference(i,e);break}c=u,i.changed.dispatch()};return i.registerDisposer(i.changed.add(l)),i.registerDisposer(e.changed.add(a)),i.registerDisposer(t.changed.add(d)),d(),i}function Wp(i,e,t,n){return gr(i,e,t,n)}class ui extends T.O8{constructor(e){super(),this.coordinateSpace=e,this.coordinates_=ps,this.changed=new j.IY,this.registerDisposer(e.changed.add(()=>{this.handleCoordinateSpaceChanged()}))}get valid(){return this.coordinateSpace.value.valid}get value(){return this.handleCoordinateSpaceChanged(),this.coordinates_}reset(){this.curCoordinateSpace=void 0,this.coordinates_=ps,this.changed.dispatch()}set value(e){const{curCoordinateSpace:t}=this;if(t===void 0||!t.valid||t.rank!==e.length)return;const{coordinates_:n}=this;n.set(e),this.changed.dispatch()}handleCoordinateSpaceChanged(){const e=this.coordinateSpace.value,t=this.curCoordinateSpace;if(e===t)return;this.curCoordinateSpace=e;const{rank:n}=e;if(!e.valid)return;if(t===void 0||!t.valid){let{coordinates_:d}=this;if(!(d!==void 0&&d.length===n)){d=this.coordinates_=new Float32Array(n),bC(d,e.bounds);const{voxelCenterAtIntegerCoordinates:u}=e.bounds;for(let h=0;h(i[i.STOP=0]="STOP",i[i.LOOP=1]="LOOP",i[i.REVERSE=2]="REVERSE",i))(Gn||{});const Hp=10;class fc{constructor(){this.velocity=Hp,this.atBoundary=2,this.paused=!0}}function Hw(i,e){return i.velocity===e.velocity&&i.atBoundary===e.atBoundary&&i.paused===e.paused}function Jw(i){return(0,f.Rf)(i),{velocity:(0,f.MM)(i,"velocity",f.zo,Hp),atBoundary:(0,f.MM)(i,"atBoundary",e=>(0,f.sl)(e,Gn),0),paused:(0,f.MM)(i,"paused",f.aO,!0)}}function jw(i){const{velocity:e,atBoundary:t,paused:n}=i;return{velocity:e,atBoundary:t===0?void 0:Gn[t].toLowerCase(),paused:n?void 0:!1}}class gc extends T.O8{constructor(e){super(),this.coordinateSpace=e,this.changed=new j.IY,this.registerDisposer(e.changed.add(()=>{this.handleCoordinateSpaceChanged()})),this.curCoordinateSpace=e.value,this.velocities_=new Array(this.curCoordinateSpace?.rank??0)}get valid(){return this.coordinateSpace.value.valid}get value(){return this.handleCoordinateSpaceChanged(),this.velocities_}set value(e){const{curCoordinateSpace:t}=this;t===void 0||t.rank!==e.length||(this.velocities_=e,this.changed.dispatch())}get(e){const t=this.coordinateSpace.value?.ids;if(t===void 0)return;const n=t.indexOf(e);return n===-1?void 0:this.value[n]}dimensionVelocity(e,t){const n=new j.IY;let s=-1;const r=()=>{const c=this.coordinateSpace.value?.ids;c===void 0?s=-1:(s===-1||c[s]!==t)&&(s=c.indexOf(t))},o=()=>{if(r(),s!==-1)return this.value[s]},a=c=>{if(r(),s===-1)return;const d=this.value;d[s]!==c&&(d[s]=c,this.changed.dispatch())},l=o();return e.registerDisposer(this.changed.add(()=>{o()!==l&&n.dispatch()})),{get value(){return o()},set value(c){a(c)},changed:n}}modifyDimension(e,t){const n=this.coordinateSpace.value?.ids;if(n===void 0)return;const s=n.indexOf(e);if(s===-1)return;const r=this.value,o=r[s],a=t(o);o!==a&&(r[s]=a,this.changed.dispatch())}togglePlayback(e,t=void 0){this.modifyDimension(e,(n=new fc)=>({...n,paused:t??!n.paused}))}playbackEnabled(e){const t=this;return{changed:this.changed,get value(){return t.get(e)!==void 0},set value(n){t.modifyDimension(e,s=>n?s??new fc:void 0)}}}multiplyVelocity(e,t){this.modifyDimension(e,(n=new fc)=>{let s=Math.round(n.velocity*t);return s===0&&(s=Math.sign(n.velocity)||1),{...n,velocity:s}})}handleCoordinateSpaceChanged(){const e=this.coordinateSpace.value,t=this.curCoordinateSpace;if(e===t)return;this.curCoordinateSpace=e;const{rank:n}=e;if(!e.valid)return;if(t===void 0){let{velocities_:l}=this;l.length===n||(l=new Array(n)),this.changed.dispatch();return}const s=new Array(n),r=this.velocities_,{ids:o}=e,{ids:a}=t;for(let l=0;lo!==void 0))return;const n={},{names:s,rank:r}=t;for(let o=0;o{this.positionLink.value===2?this.changed.dispatch():this.peer.assign(this.velocity)});const n=()=>{this.positionLink.value!==2&&this.velocity.assign(this.peer)};this.registerDisposer(e.changed.add(n)),n()}toJSON(){if(this.positionLink.value===2)return this.velocity.toJSON()}reset(){this.positionLink.value===2&&this.velocity.reset()}restoreState(e){this.positionLink.value===2&&this.velocity.restoreState(e)}copyToPeer(){this.positionLink.value===2&&this.peer.assign(this.velocity)}}class mc extends T.O8{constructor(e,t,n){super(),this.display=e,this.position=t,this.velocity=n,this.dimensionStates=new Map,this.lastUpdateGeneration=0,this.handleVelocityChanged(),this.registerDisposer(n.changed.add(()=>this.handleVelocityChanged()))}disposed(){this.unregisterUpdateStartedCallback?.(),super.disposed()}handleVelocityChanged(){const{dimensionStates:e}=this,t=this.position.coordinateSpace.value?.ids??[],n=t.length,s=this.velocity.value,r=++this.lastUpdateGeneration,o=this.position.value,a=Date.now();for(let l=0;lthis.updateStarted()),this.display.scheduleRedraw())}updateStarted(){const e=this.position.coordinateSpace.value;if(e===void 0)return;const t=e.ids,n=this.position.value;let s=!1,r=!1;const o=Date.now(),a=this.velocity.value,{bounds:{lowerBounds:l,upperBounds:c}}=e;for(const[d,u]of this.dimensionStates){const{dimensionIndex:h}=u;if(t[h]!==d)continue;const p=a[h];if(Math.floor(n[h])!==Math.floor(u.prevCoordinate)){p?.paused===!1&&(a[h]={...p,paused:!0},r=!0);continue}const m=o-u.prevTime,g=p?.velocity??0,v=m*g/1e3;if(v===0)continue;let y=n[h]+v;const S=l[h],w=Math.ceil(c[h]-1),b=v>0?w:S,x=v>0?S:w,E=Math.sign(v);if(Number.isFinite(b)&&y*E>=b*E)switch(p.atBoundary){case 1:if(Number.isFinite(x)){y=x;break}case 0:a[h]={...p,paused:!0},r=!0,y=b;break;case 2:a[h]={...p,velocity:-g},r=!0,y=b;break}n[h]=y,u.prevCoordinate=n[h],u.prevTime=o,s=!0}s&&this.position.changed.dispatch(),r&&this.velocity.changed.dispatch(),this.display.scheduleRedraw()}}function Jp(i,e,t){if(t===void 0||Object.keys(t).length===0){i.value=0;return}(0,f.Rf)(t),i.value=2,(0,f.cQ)(t,"value",n=>{n!==void 0&&e.restoreState(n)}),(0,f.cQ)(t,"link",n=>i.restoreState(n))}class mr{constructor(e,t=new Ww){this.peer=e,this.link=t}get changed(){return this.value.changed}toJSON(){const{link:e}=this;if(e.value!==0)return{link:e.toJSON(),value:this.getValueJson()}}getValueJson(){return this.value.toJSON()}reset(){this.link.value=0}restoreState(e){Jp(this.link,this.value,e)}copyToPeer(){this.link.value!==0&&(this.link.value=2,this.peer.assign(this.value),this.link.value=0)}}class jp extends mr{}class Yp extends mr{constructor(){super(...arguments),this.value=gr(new ui(this.peer.coordinateSpace),this.peer,this.link,{assign:(e,t)=>e.assign(t),isValid:e=>e.valid,difference:ui.getOffset,add:ui.addOffset,subtract:(e,t,n)=>{ui.addOffset(e,t,n,-1)}})}}function Qw(i){return i[0]===0&&i[1]===0&&i[2]===0&&i[3]===1}class bs extends T.O8{constructor(e){super(),this.changed=new j.IY,e==null&&(e=C.Yu.create()),this.orientation=e}toJSON(){const{orientation:e}=this;if(C.Yu.normalize(this.orientation,this.orientation),!Qw(e))return Array.prototype.slice.call(this.orientation)}restoreState(e){try{(0,f.Vr)(this.orientation,e),C.Yu.normalize(this.orientation,this.orientation)}catch{C.Yu.identity(this.orientation)}this.changed.dispatch()}reset(){C.Yu.identity(this.orientation),this.changed.dispatch()}snap(){const e=C.w0.create();C.w0.fromQuat(e,this.orientation);const t=[!1,!1,!1];for(let n=0;n<3;++n){let s=0,r=0;for(let o=0;o<3;++o){const a=e[n*3+o];e[n*3+o]=0,!t[o]&&Math.abs(a)>Math.abs(s)&&(s=a,r=o)}e[n*3+r]=Math.sign(s),t[r]=!0}C.Yu.fromMat3(this.orientation,e),this.changed.dispatch()}static makeRelative(e,t){const n=new bs(C.Yu.multiply(C.Yu.create(),e.orientation,t));let s=!1;n.registerDisposer(e.changed.add(()=>{s||(r=!0,C.Yu.multiply(n.orientation,e.orientation,t),n.changed.dispatch(),r=!1)}));let r=!1;const o=C.Yu.invert(C.Yu.create(),t);return n.registerDisposer(n.changed.add(()=>{r||(s=!0,C.Yu.multiply(e.orientation,n.orientation,o),e.changed.dispatch(),s=!1)})),n}assign(e){C.Yu.copy(this.orientation,e.orientation),this.changed.dispatch()}}class vc extends mr{constructor(){super(...arguments),this.value=gr(new bs,this.peer,this.link,{assign:(e,t)=>e.assign(t),isValid:()=>!0,difference:(e,t)=>{const n=C.Yu.create();return C.Yu.multiply(n,C.Yu.invert(n,t.orientation),e.orientation)},add:(e,t,n)=>{C.Yu.multiply(e.orientation,t.orientation,n),e.changed.dispatch()},subtract:(e,t,n)=>{C.Yu.multiply(e.orientation,t.orientation,C.Yu.invert(zp,n)),e.changed.dispatch()}})}}class Qp extends T.O8{constructor(e){super(),this.coordinateSpace=e,this.changed=new j.IY,this.curCoordinateSpace=Fn,this.value_={factors:new Float64Array(0)},this.registerDisposer(e.changed.add(()=>this.update())),this.update()}get value(){return this.update()}reset(){this.value_={factors:new Float64Array(0)},this.curCoordinateSpace=Fn,this.changed.dispatch()}toJSON(){const e={};let t=!1;const{value:n}=this,{factors:s}=n,{names:r,rank:o}=this.curCoordinateSpace;for(let a=0;al===void 0?1:(0,f.Mo)(l))}this.value_={factors:r},this.curCoordinateSpace=t,this.changed.dispatch()}setFactors(e){const{coordinateSpace:{value:t}}=this;e.length===t.rank&&(this.value_={factors:e},this.curCoordinateSpace=t,this.changed.dispatch())}update(){const{coordinateSpace:{value:e}}=this;let t=this.value_;const{curCoordinateSpace:n}=this;if(n===e)return t;const{ids:s}=n,{ids:r,rank:o}=e,a=t.factors,l=new Float64Array(o);l.fill(1);for(let c=0;ce.assign(t),difference:(e,t)=>{const{factors:n}=e.value,s=e.coordinateSpace.value,r=t.value.factors;return{coordinateSpace:s,offsets:Ul(new Float64Array(n.length),n,r)}},add:(e,t,n)=>{const s=Kp(Float64Array,n.offsets,n.coordinateSpace,e.coordinateSpace.value,()=>0);e.setFactors(Ah(new Float64Array(s.length),s,t.value.factors))},subtract:(e,t,n)=>{const s=Kp(Float64Array,n.offsets,n.coordinateSpace,e.coordinateSpace.value,()=>0);e.setFactors(Ul(new Float64Array(s.length),t.value.factors,s))},isValid:()=>!0})}}function qp(i,e,t){const{rank:n,names:s,units:r}=i,{displayRank:o,displayDimensionIndices:a}=e,l=new Float64Array(3),c=new Float64Array(3);let d;const{factors:u}=t,h=new Array(3),p=new Float64Array(3);if(l.fill(1),c.fill(1),p.fill(1),h.fill(""),o===0)d=1;else{d=Number.POSITIVE_INFINITY;const{scales:m}=i;for(let g=0;g{this.value};this.registerDisposer(e.changed.add(n)),this.registerDisposer(t.changed.add(n))}get value(){const{relativeDisplayScales:{value:e,coordinateSpace:{value:t}},displayDimensions:{value:n},curRelativeDisplayScales:s,curDisplayDimensions:r,curCoordinateSpace:o}=this;let a=this.value_;if(s!==e||r!==n||o!==t){this.curRelativeDisplayScales=e,this.curDisplayDimensions=n,this.curCoordinateSpace=t;const l=qp(t,n,e);Xp(a,l)||(this.value_=a=l,this.changed.dispatch())}return a}}class ef extends T.O8{constructor(e){super(),this.coordinateSpace=e,this.changed=new j.IY,this.default_=!0,this.value_=void 0,this.registerDisposer(this.coordinateSpace.changed.add(this.changed.dispatch)),this.update()}get value(){return this.update(),this.value_}update(){const{coordinateSpace:{value:e}}=this,t=this.value_;if(t!==void 0&&t.coordinateSpace===e)return;if(t===void 0||this.default_){this.setToDefault(e);return}const n=new Int32Array(3),{ids:s}=t.coordinateSpace,{ids:r}=e,o=t.displayDimensionIndices,a=t.displayRank;let l=0;for(let c=0;c3)throw new Error("Number of spatial dimensions must be <= 3");const{coordinateSpace:{value:n}}=this,s=new Int32Array(3);s.fill(-1);const{names:r}=n;let o=0;for(const a of t){const l=r.indexOf(a);l!==-1&&(s[o++]=l)}if(o===0){this.reset();return}this.default_=!1,this.assignValue(n,o,s)}get default(){return this.update(),this.default_}set default(e){this.default_!==e&&(e?(this.default_=!0,this.setToDefault(this.coordinateSpace.value)):(this.default_=!1,this.changed.dispatch()))}setDimensionIndices(e,t){this.default_=!1,this.assignValue(this.coordinateSpace.value,e,t)}toJSON(){if(this.default_)return;const{value:e}=this,t=[],{displayRank:n,displayDimensionIndices:s,coordinateSpace:{names:r}}=e;if(n!==0){for(let o=0;oe.assign(t),isValid:()=>!0})}}class Cs extends T.O8{constructor(e,t,n){super(),this.position=e,this.displayDimensionRenderInfo=t,this.orientation=n,this.changed=new j.IY,this.registerDisposer(e),this.registerDisposer(n),this.registerDisposer(t),this.registerDisposer(e.changed.add(this.changed.dispatch)),this.registerDisposer(n.changed.add(this.changed.dispatch)),this.registerDisposer(t.changed.add(this.changed.dispatch))}get displayDimensions(){return this.displayDimensionRenderInfo.displayDimensions}get relativeDisplayScales(){return this.displayDimensionRenderInfo.relativeDisplayScales}get valid(){return this.position.valid}reset(){this.position.reset(),this.orientation.reset(),this.displayDimensions.reset()}updateDisplayPosition(e,t=ko){const{coordinateSpace:{value:n},value:s}=this.position,{displayDimensionIndices:r,displayRank:o}=this.displayDimensions.value;if(n===void 0)return!1;t.fill(0);for(let a=0;a{const n=new e.constructor(t),s=(c,d)=>{c.assign(d)},r=(c,d)=>c.value/d.value*(c.canonicalVoxelPhysicalSize/d.canonicalVoxelPhysicalSize),o=(c,d,u)=>{c.setPhysicalScale(d.value*u,d.canonicalVoxelPhysicalSize)},a=(c,d,u)=>{c.setPhysicalScale(d.value/u,d.canonicalVoxelPhysicalSize)},l=c=>c.coordinateSpaceValue.valid&&c.canonicalVoxelPhysicalSize!==0;return gr(n,this.peer,this.link,{assign:s,isValid:l,difference:r,add:o,subtract:a}),n})()}}function vr(i){return{changed:i.changed,toJSON(){return i.toJSON()},restoreState(e){Jp(i.link,i.value.legacyJsonView,e)},reset(){i.reset()}}}class tf extends T.O8{constructor(e){super(),this.displayDimensionRenderInfo=e,this.changed=new j.IY,this.curCanonicalVoxelPhysicalSize=0,this.value_=Number.NaN,this.legacyValue_=Number.NaN,this.registerDisposer(e),this.registerDisposer(e.changed.add(()=>this.handleCoordinateSpaceChanged())),this.registerDisposer(e.relativeDisplayScales.coordinateSpace.changed.add(()=>this.handleCoordinateSpaceChanged())),this.handleCoordinateSpaceChanged()}get value(){return this.handleCoordinateSpaceChanged(),this.value_}set value(e){const{canonicalVoxelPhysicalSize:t}=this;Object.is(e,this.value_)&&t===this.curCanonicalVoxelPhysicalSize||(this.curCanonicalVoxelPhysicalSize=t,this.legacyValue_=Number.NaN,this.value_=e,this.changed.dispatch())}get canonicalVoxelPhysicalSize(){return this.displayDimensionRenderInfo.value.canonicalVoxelPhysicalSize}get coordinateSpaceValue(){return this.displayDimensionRenderInfo.relativeDisplayScales.coordinateSpace.value}set legacyValue(e){Object.is(e,this.legacyValue_)||(this.value_=Number.NaN,this.legacyValue_=e,this.curCanonicalVoxelPhysicalSize=0,this.changed.dispatch())}get legacyValue(){return this.legacyValue_}handleCoordinateSpaceChanged(){const{value_:e}=this,{displayDimensionRenderInfo:{value:{canonicalVoxelPhysicalSize:t},relativeDisplayScales:{coordinateSpace:{value:n}}}}=this,{curCanonicalVoxelPhysicalSize:s}=this;if(!(!Number.isNaN(e)&&t===s)){if(!Number.isNaN(e)){s!==0&&(this.value_=e*(s/t),this.curCanonicalVoxelPhysicalSize=t,this.changed.dispatch());return}!n.valid||t===0||(this.curCanonicalVoxelPhysicalSize=t,this.value_=this.getDefaultValue(),this.changed.dispatch())}}toJSON(){const{value:e}=this;return Number.isNaN(e)?void 0:e}restoreState(e){this.curCanonicalVoxelPhysicalSize=0,this.legacyValue_=Number.NaN,e===void 0?this.value_=Number.NaN:this.value_=(0,f.Mo)(e),this.changed.dispatch()}reset(){this.curCanonicalVoxelPhysicalSize=0,this.value_=Number.NaN,this.legacyValue_=Number.NaN,this.changed.dispatch()}get legacyJsonView(){const e=this;return{changed:e.changed,toJSON(){return e.toJSON()},reset(){return e.reset()},restoreState(t){e.legacyValue=(0,f.Mo)(t)}}}setPhysicalScale(e,t){const n=this.curCanonicalVoxelPhysicalSize=this.canonicalVoxelPhysicalSize;this.value=e*(t/n)}assign(e){const{legacyValue:t}=e;Number.isNaN(t)?this.setPhysicalScale(e.value,e.canonicalVoxelPhysicalSize):this.legacyValue=t}}class Zw extends tf{getDefaultValue(){const{legacyValue_:e}=this;if(Number.isNaN(e))return 1;const{canonicalVoxelPhysicalSize:t}=this;return this.legacyValue_*1e-9/t}}class ex extends tf{getDefaultValue(){const{legacyValue_:e}=this;if(!Number.isNaN(e)){this.legacyValue_=Number.NaN;const{canonicalVoxelPhysicalSize:a}=this;return 200*Math.tan(Math.PI/8)*1e-9*e/a}const{coordinateSpaceValue:{bounds:{lowerBounds:t,upperBounds:n}}}=this,{canonicalVoxelFactors:s,displayDimensionIndices:r}=this.displayDimensionRenderInfo.value;let o=s.reduce((a,l,c)=>{const d=r[c],u=(n[d]-t[d])*l;return Math.max(a,u)},0);return Number.isFinite(o)?o=2**Math.ceil(Math.log2(o)):o=1024,o}}class Sc extends T.O8{constructor(e,t){super(),this.defaultValue=e,this.displayDimensionRenderInfo=t,this.changed=new j.IY,this.value_=e,this.canonicalVoxelPhysicalSize=t.value.canonicalVoxelPhysicalSize,this.registerDisposer(t.changed.add(()=>{this.value}))}get value(){let{value_:e}=this;if(e>0){const{canonicalVoxelPhysicalSize:t}=this.displayDimensionRenderInfo.value,n=this.canonicalVoxelPhysicalSize;t!==n&&(this.canonicalVoxelPhysicalSize=t,e=this.value_=e=n/t,this.changed.dispatch())}return e}set value(e){if(e===this.value)return;this.value_=e;const{canonicalVoxelPhysicalSize:t}=this.displayDimensionRenderInfo.value;this.canonicalVoxelPhysicalSize=t,this.changed.dispatch()}toJSON(){const{value:e}=this;if(e!==this.defaultValue)return e}reset(){this.value=this.defaultValue}restoreState(e){typeof e!="number"||!Number.isFinite(e)||e===0?this.value=this.defaultValue:this.value=e}setValueAbsolute(e,t){if(e>0){const{canonicalVoxelPhysicalSize:n}=this.displayDimensionRenderInfo.value;e=e*(t/n)}this.value=e}assign(e){this.setValueAbsolute(e.value,e.canonicalVoxelPhysicalSize)}}class nf extends jp{constructor(e,t){super(e),this.value=Wp(new Sc(e.defaultValue,t),this.peer,this.link,{assign:(n,s)=>n.assign(s),isValid:()=>!0})}}class ws extends T.O8{constructor(e,t,n){super(),this.pose=e,this.zoomFactor=t,this.depthRange=n,this.changed=new j.IY,this.registerDisposer(e),this.registerDisposer(t),this.registerDisposer(n),this.registerDisposer(this.pose.changed.add(this.changed.dispatch)),this.registerDisposer(this.zoomFactor.changed.add(this.changed.dispatch)),this.registerDisposer(this.depthRange.changed.add(this.changed.dispatch))}get coordinateSpace(){return this.pose.position.coordinateSpace}reset(){this.pose.reset(),this.zoomFactor.reset()}get position(){return this.pose.position}get displayDimensions(){return this.pose.displayDimensions}get relativeDisplayScales(){return this.pose.relativeDisplayScales}get displayDimensionRenderInfo(){return this.pose.displayDimensionRenderInfo}toMat4(e){this.pose.toMat4(e,this.zoomFactor.value)}toMat3(e){this.pose.toMat3(e,this.zoomFactor.value)}get relativeDepthRange(){let e=this.depthRange.value;return e>0?e/=this.zoomFactor.value:e*=-1,e}get valid(){return this.pose.valid&&!Number.isNaN(this.zoomFactor.value)}zoomBy(e){this.zoomFactor.value*=e}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class tx{constructor(e){if(this.parents=new Array,this.parentPriorities=new Array,this.bindings=new Map,e!==void 0){this.parents.push(...e.parents),this.parentPriorities.push(...e.parentPriorities);for(const[t,n]of e.bindings)this.bindings.set(t,n)}}addParent(e,t){const{parents:n,parentPriorities:s}=this;let r=0;const{length:o}=n;for(;r{this.removeParent(e)}}removeParent(e){const t=this.parents.indexOf(e);if(t===-1)throw new Error("Attempt to remove non-existent parent map.");this.parents.splice(t,1),this.parentPriorities.splice(t,1)}set(e,t){this.bindings.set(e,t)}delete(e){this.bindings.delete(e)}clear(){this.bindings.clear(),this.parents.length=0,this.parentPriorities.length=0}get(e){const{parents:t,parentPriorities:n}=this,s=n.length;let r=0,o;for(;r0;++r)if(o=t[r].get(e),o!==void 0)return o;if(o=this.bindings.get(e),o!==void 0)return o;for(;r0;)o=t[r].get(e),o!==void 0&&(yield o);for(o=this.bindings.get(e),o!==void 0&&(yield o);r0;++s)yield*e[s].entries();for(yield*this.bindings.entries();s(i[i.CONTROL=1]="CONTROL",i[i.ALT=2]="ALT",i[i.META=4]="META",i[i.SHIFT=8]="SHIFT",i))(sf||{});function bc(i){return(i.ctrlKey?1:0)|(i.altKey?2:0)|(i.metaKey?4:0)|(i.shiftKey?8:0)}function Cc(i,e){let t="";return e&1&&(t+="control+"),e&2&&(t+="alt+"),e&4&&(t+="meta+"),e&8&&(t+="shift+"),t+=i,t}function nx(i,e,t){let n="";return e&1&&(n+="control+"),t&1&&(n+="control?+"),e&2&&(n+="alt+"),t&2&&(n+="alt?+"),e&4&&(n+="meta+"),t&4&&(n+="meta?+"),e&8&&(n+="shift+"),t&8&&(n+="shift?+"),n+=i,n}function rf(i){const e=i.indexOf(":");let t;if(e!==-1&&(t=i.substring(0,e),t!=="at"&&t!=="bubble"))throw new Error(`Invalid event phase: ${JSON.stringify(t)}`);const n=i.substring(e+1).split("+");let s,r=0,o=0;e:for(const a of n)switch(a){case"control":r|=1;break;case"control?":o|=1;break;case"alt":r|=2;break;case"alt?":o|=2;break;case"meta":r|=4;break;case"meta?":o|=4;break;case"shift":r|=8;break;case"shift?":o|=8;break;default:if(s===void 0)s=a;else{s=void 0;break e}}if(s===void 0||r&o)throw new Error(`Invalid event identifier: ${JSON.stringify(i)}`);return{phase:t,keyName:s,modifiers:r,optionalModifiers:o}}function*ix(i,e,t){t===0&&(yield Cc(i,e));for(let n=0;n<16;++n)(n&(e|t))===n&&(n&e)===e&&(yield Cc(i,n))}function*of(i){const{phase:e}=i,t=ix(i.keyName,i.modifiers,i.optionalModifiers);if(e===void 0)for(const n of t)yield`at:${n}`,yield`bubble:${n}`;else for(const n of t)yield`${e}:${n}`}function sx(i,e){const t=nx(i.keyName,i.modifiers,i.optionalModifiers);return typeof e=="string"?{action:e,originalEventIdentifier:t}:{...e,originalEventIdentifier:t}}function rx(i){return i=i.replace(/^(?:at|bubble|capture)|(?:(?:shift|control|alt|meta)\?\+)/g,""),i}class Ae extends tx{static fromObject(e,t={}){const n=new Ae;if(n.label=t.label,t.parents!==void 0)for(const[s,r]of t.parents)n.addParent(s,r);for(const s of Object.keys(e))n.set(s,e[s]);return n}setFromObject(e){for(const t of Object.keys(e))this.set(t,e[t])}set(e,t){const n=rf(e),s=sx(n,t);for(const r of of(n))super.set(r,s)}delete(e){for(const t of of(rf(e)))super.delete(t)}describe(){const e=[],t=new Map;for(const[,s]of this.entries())t.set(s.originalEventIdentifier,s.action);const n=new Map;for(const[s,r]of t){let o=n.get(r);o===void 0&&(o=[],n.set(r,o)),o.push(rx(s))}for(const[s,r]of n){const o=r.length===1?r[0]:`{${r.join(",")}}`;e.push(`${o}\u2192${s}`)}return e.join(", ")}}function af(i,e,t){if(t===void 0)return;t.stopPropagation!==!1&&i.stopPropagation();const n=new CustomEvent("action:"+t.action,{bubbles:!0,detail:e,cancelable:!0}),s=!i.target.dispatchEvent(n);(t.preventDefault!==!1||s)&&i.preventDefault()}const Po=[];Po[Event.AT_TARGET]="at",Po[Event.CAPTURING_PHASE]="capture",Po[Event.BUBBLING_PHASE]="bubble";function lf(i,e,t,n,s){const r=Po[t]+":"+i,o=s.get(r);af(e,n,o)}function cf(i,e,t,n){lf(Cc(i,bc(e)),e,e.eventPhase,t,n)}function Z(i,e,t,n){return(0,T.K6)(i,`action:${e}`,t,n)}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class tn extends T.O8{constructor(e,t,n){super(),this.target=e,this.eventMap=t,this.shouldIgnore=void 0,this.registerEventListener(e,"wheel",s=>{n!==void 0&&n(s),this.dispatch("wheel",s)}),this.registerEventListener(e,"click",s=>{n!==void 0&&n(s),this.dispatch(`click${s.button}`,s)}),this.registerEventListener(e,"dblclick",s=>{n!==void 0&&n(s),this.dispatch(`dblclick${s.button}`,s)}),this.registerEventListener(e,"mousedown",s=>{n!==void 0&&n(s);let r=s.button;r===2&&(s.buttons&3)===1&&(r=0),this.dispatch(`mousedown${r}`,s)}),this.registerEventListener(e,"mouseup",s=>{n!==void 0&&n(s),this.dispatch(`mouseup${s.button}`,s)})}dispatch(e,t){this.shouldIgnore?.(t)||cf(e,t,t,this.eventMap)}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function zt(i,e,t){const{document:n}=i.view;let s=i.clientX,r=i.clientY;const o=d=>{const u=d.clientX-s,h=d.clientY-r;s=d.clientX,r=d.clientY,e(d,u,h)},a=i.button,l=d=>{n.removeEventListener("pointermove",o,!0),n.removeEventListener("pointerup",c,!1),t!==void 0&&t(d,d.clientX-s,d.clientY-r)},c=d=>{d.button===a&&l(d)};n.addEventListener("pointermove",o,!0),n.addEventListener("pointerup",c,!1),n.addEventListener("pointercancel",l,!1)}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const ox=0,ax=1,lx=2;function _i(i){let e=0;const{deltaMode:t}=i;switch(t){case ox:e=.005;break;case ax:e=.1;break;case lx:e=2;break}return Math.exp(i.deltaY*e)}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const yr=6,FV=2,wc=` +vec2 getQuadVertexPosition(vec2 lower, vec2 upper) { + const vec2 coeffs[] = vec2[]( + vec2(0.0, 0.0), + vec2(0.0, 1.0), + vec2(1.0, 1.0), + vec2(1.0, 1.0), + vec2(1.0, 0.0), + vec2(0.0, 0.0) + ); + int v = gl_VertexID % 6; + return mix(lower, upper, coeffs[v]); +} +`;function Ao(i,e,t){i.drawArraysInstanced(WebGL2RenderingContext.TRIANGLES,0,yr*e,t)}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Ut=yr;function In(i,e=!1){i.addVertexCode(wc),i.addUniform("highp vec3","uLineParams"),i.addVarying("highp float","vLineCoord"),i.addVarying("highp float","vLineFeatherFraction"),e&&(i.addVarying("highp float","vEndpointFraction"),i.addVarying("highp float","vLineCoordT"),i.addVarying("highp float","vLineBorderStartFraction")),i.addVertexCode(Aw),i.addVertexCode(` +vec2 getLineOffset() { return getQuadVertexPosition(vec2(0.0, -1.0), vec2(1.0, 1.0)); } +float getLineEndpointCoefficient() { return getLineOffset().x; } +uint getLineEndpointIndex() { return uint(getLineEndpointCoefficient()); } +void emitLine(vec4 vertexAClip, vec4 vertexBClip, float lineWidthInPixels + ${e?", float borderWidth":""}) { + if (!clipLineToDepthRange(vertexAClip, vertexBClip)) { + gl_Position = vec4(2.0, 2.0, 2.0, 1.0); + return; + } + vec3 vertexADevice = vertexAClip.xyz / vertexAClip.w; + vec3 vertexBDevice = vertexBClip.xyz / vertexBClip.w; + + vec2 lineDirectionUnnormalized = vertexBDevice.xy - vertexADevice.xy; + vec2 lineDirection; + float linePixelLength = length(lineDirectionUnnormalized / uLineParams.xy * 0.5); + + if (linePixelLength < 1e-3) { + lineDirection = vec2(1.0, 0.0); + vertexADevice.z = vertexBDevice.z = 0.0; + } else { + lineDirection = normalize(lineDirectionUnnormalized); + } + vec2 lineNormal = normalize(vec2(lineDirection.y, -lineDirection.x) / uLineParams.yx * uLineParams.xy); + + vec2 lineOffset = getLineOffset(); + gl_Position = vec4(mix(vertexADevice, vertexBDevice, lineOffset.x), 1.0); + float totalLineWidth = lineWidthInPixels + 2.0 * uLineParams.z ${e?" + 2.0 * borderWidth":""}; + if (lineWidthInPixels == 0.0) totalLineWidth = 0.0; + vLineFeatherFraction = max(1e-6, uLineParams.z) / totalLineWidth; + gl_Position.xy += (lineOffset.y * lineNormal + ${e?"+ lineDirection * (2.0 * lineOffset.x - 1.0)":""}) + * totalLineWidth * uLineParams.xy; + vLineCoord = lineOffset.y; + ${e?"vEndpointFraction = totalLineWidth / (linePixelLength + totalLineWidth * 2.0);":""} + ${e?"vLineCoordT = lineOffset.x; vLineBorderStartFraction = lineWidthInPixels / totalLineWidth;":""} +} +void emitLine(mat4 projection, vec3 vertexA, vec3 vertexB, float lineWidthInPixels + ${e?", float borderWidth":""}) { + emitLine(projection * vec4(vertexA, 1.0), projection * vec4(vertexB, 1.0), + lineWidthInPixels + ${e?", borderWidth":""}); +} +`),e&&i.addFragmentCode(` +vec4 getRoundedLineColor(vec4 interiorColor, vec4 borderColor) { + float radius; + if (vLineCoordT < vEndpointFraction || vLineCoordT > 1.0 - vEndpointFraction) { + radius = length(vec2(1.0 - min(vLineCoordT, 1.0 - vLineCoordT) / vEndpointFraction, + vLineCoord)); + if (radius > 1.0) { + discard; + } + } else { + radius = abs(vLineCoord); + } + float borderColorFraction = clamp((radius - vLineBorderStartFraction) / vLineFeatherFraction, 0.0, 1.0); + float feather = clamp((1.0 - radius) / vLineFeatherFraction, 0.0, 1.0); + vec4 color = mix(interiorColor, borderColor, borderColorFraction); + return vec4(color.rgb, color.a * feather); +} +`),i.addFragmentCode(` +float getLineAlpha() { + return clamp((1.0 - abs(vLineCoord)) / vLineFeatherFraction, 0.0, 1.0); +} +`)}function mn(i,e,t){Ao(i,e,t)}function vn(i,e,t){const{gl:n}=i;n.uniform3f(i.uniform("uLineParams"),1/e.width,1/e.height,t)}/** + * @license + * Copyright 2024 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function df(i,e=-1,t=1,n=1,s=-1){const r=new Float32Array(i*yr*2),o=(t-e)/i;let a=e;for(let l=0;l1&&(i[0]-=1)}return i}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class hi extends T.O8{constructor(e,t=()=>C.eR.fromValues(1,0,0),n=hi.template(),s=()=>{},r=!0){super(),this.model=e,this.getDefaultColor=t,this.element=n,this.unsetHandler=s,n.addEventListener("change",()=>this.updateModel()),n.addEventListener("input",()=>this.updateModel()),r&&n.addEventListener("wheel",o=>{o.stopPropagation(),o.preventDefault(),this.adjustHueViaWheel(o)}),n.addEventListener("mousedown",o=>{o.button===2&&(o.stopPropagation(),s())}),this.registerDisposer(e.changed.add(()=>this.updateView())),this.updateView()}static template(){const e=document.createElement("input");return e.classList.add("neuroglancer-color-widget"),e.type="color",e}getRGB(){return this.model.value??this.getDefaultColor()}updateView(){this.element.value=Ge(this.getRGB())}updateModel(){this.model.value=me(this.element.value)}adjustHueViaWheel(e){const t=this.getRGB(),n=C.eR.create();cx(n,t[0],t[1],t[2]);const{deltaY:s}=e;let r=Math.round(n[0]*256);r+=s>0?1:s<0?-1:0,r=(r+256)%256,n[0]=r/256,Mo(n,n[0],n[1],n[2]),this.model.value=n}}var uf=G(2104),hf=G(2809);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Me(i){for(;;){const e=i.firstChild;if(!e)break;i.removeChild(e)}}function at(i){const{parentElement:e}=i;return e?(e.removeChild(i),!0):!1}function $t(i,e=Math.max(1,i.value.length)){const t=`${e}ch`;i.style.width!==t&&(i.style.width="0px",i.offsetWidth,i.style.width=t)}function nn(i,e){let t=i.firstElementChild;for(const n of e)n!==t&&i.insertBefore(n,t),t=n.nextElementSibling;for(;t!==null;){const n=t.nextElementSibling;i.removeChild(t),t=n}}function xc(i){return i instanceof HTMLElement?!!(i instanceof HTMLInputElement||i instanceof HTMLTextAreaElement||i.isContentEditable):!1}function dx(i){const e=i.cloneNode(!0);return e.style.position="absolute",document.body.appendChild(e),e.getBoundingClientRect()}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function $V(i){const e=Ne(i);return i.svgHover&&(e.classList.add("neuroglancer-icon-hover"),e.innerHTML+=i.svgHover),e}function Ne(i){const{title:e,onClick:t,href:n}=i;let s;n!==void 0?(s=document.createElement("a"),s.href=n,s.target="_blank"):s=document.createElement("div"),e!==void 0&&(s.title=e),t!==void 0&&s.addEventListener("click",t);const{svg:r}=i;return s.className="neuroglancer-icon",r!==void 0&&(s.innerHTML=r),i.text!==void 0&&s.appendChild(document.createTextNode(i.text)),s}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Gt extends T.O8{constructor(e=new vt(vt.VISIBLE)){super(),this.visibility=e,this.element=document.createElement("div");const{element:t}=this;t.classList.add("neuroglancer-tab-content")}get visible(){return this.visibility.visible}disposed(){at(this.element),super.disposed()}}class ux extends T.O8{constructor(){super(...arguments),this.changed=new j.IY,this.options=new Map,this.optionsChanged=new j.IY,this.selectedValue=void 0,this.defaultValue=void 0,this.ready_=!0}get value(){const{selectedValue:e}=this;return e!==void 0?e:this.defaultValue}set default(e){this.defaultValue!==e&&(this.defaultValue=e,this.changed.dispatch())}get default(){return this.defaultValue}set value(e){e!==void 0&&this.ready_&&!this.options.has(e)&&(e=void 0);const{selectedValue:t}=this;t!==e&&(this.selectedValue=e,this.changed.dispatch())}get validValue(){const e=this.selectedValue;return e===void 0||!this.options.has(e)?this.defaultValue:e}add(e,t){const{options:n}=this;if(n.has(e))throw new Error(`Option already defined: ${JSON.stringify(e)}.`);n.set(e,t),this.optionsChanged.dispatch(),this.defaultValue===void 0&&(this.default=e)}remove(e){const{options:t}=this;if(!t.has(e))throw new Error(`Option is not defined: ${JSON.stringify(e)}.`);t.delete(e),this.optionsChanged.dispatch()}toJSON(){const{value:e,defaultValue:t}=this;if(e!==t)return e}reset(){this.value=void 0}get ready(){return this.ready_}set ready(e){e!==this.ready_&&(this.ready_=e,e&&(this.value=this.value),this.changed.dispatch())}restoreState(e){typeof e!="string"&&(e=void 0),this.value=e}}class hx extends T.O8{constructor(e,t,n=new vt(vt.VISIBLE),s=!1){super(),this.getter=e,this.selected=t,this.visibility=n,this.invalidateByDefault=s,this.element=document.createElement("div"),this.tabs=new Map,this.tabVisibilityChanged=new j.HN,this.debouncedUpdateSelectedTab=this.registerCancellable((0,Qe.t)(()=>this.updateSelectedTab()));const{element:r}=this;r.className="neuroglancer-stack-view",this.registerDisposer(n.changed.add(this.debouncedUpdateSelectedTab)),this.registerDisposer(t.changed.add(this.debouncedUpdateSelectedTab)),this.updateSelectedTab()}get visible(){return this.visibility.visible}flush(){this.debouncedUpdateSelectedTab.flush()}invalidate(e){const{tabs:t}=this,n=t.get(e);n!==void 0&&(n.dispose(),t.delete(e),e===this.displayedTab&&(this.displayedTab=void 0,this.debouncedUpdateSelectedTab()))}hideTab(e){const t=this.tabs.get(e);t!==void 0&&(t.visibility.value=vt.IGNORED,t.element.style.display="none"),this.tabVisibilityChanged.dispatch(e,!1)}showTab(e){const{tabs:t}=this;let n=t.get(e);n===void 0&&(n=this.getter(e),this.element.appendChild(n.element),t.set(e,n)),n.element.style.display="",n.visibility.value=vt.VISIBLE,this.tabVisibilityChanged.dispatch(e,!0)}updateSelectedTab(){const{displayedTab:e}=this,t=this.visible?this.selected.value:void 0;t===e&&(t===void 0||this.tabs.has(t))||(e!==void 0&&this.hideTab(e),this.invalidateByDefault&&this.invalidateAll(),this.displayedTab=t,t!==void 0&&this.showTab(t))}invalidateAll(e=void 0){const{tabs:t}=this;for(const[n,s]of t)e?.(n)||(t.delete(n),s.dispose());this.debouncedUpdateSelectedTab()}disposed(){this.invalidateAll(),at(this.element),super.disposed()}}class px extends ux{}function fx(i,e){const t="neuroglancer-selected-tab-label";e?i.classList.add(t):i.classList.remove(t)}class gx extends T.O8{constructor(e,t=new vt(vt.VISIBLE)){super(),this.visibility=t,this.element=document.createElement("div"),this.tabBar=document.createElement("div"),this.tabLabels=new Map,this.tabsGeneration=-1,this.debouncedUpdateView=this.registerCancellable((0,Qe.t)(()=>this.updateTabs())),this.tabs=e.tabs,this.selectedTab=e.selectedTab,this.handleTabElement=e.handleTabElement;const{element:n,tabBar:s}=this;n.className="neuroglancer-tab-view",s.className="neuroglancer-tab-view-bar",n.appendChild(s),this.registerDisposer(t.changed.add(this.debouncedUpdateView));const r=this.stack=this.registerDisposer(new hx(e.makeTab,e.selectedTab,this.visibility));n.appendChild(r.element),this.registerDisposer(e.tabs.changed.add(this.debouncedUpdateView));let o=this.selectedTab.value;this.registerDisposer(e.selectedTab.changed.add(()=>{this.tabs.value.find(({id:c})=>c===o)?.hidden?(this.tabs.changed.count++,this.debouncedUpdateView()):this.updateTabLabelStyles(),o=this.selectedTab.value})),this.updateTabs()}get visible(){return this.visibility.visible}updateTabLabelStyles(){const e=this.selectedTab.value;for(const[t,n]of this.tabLabels)fx(n,t===e)}updateTabs(){this.tabsGeneration!==this.tabs.changed.count&&(this.destroyTabs(),this.visible&&this.makeTabs())}destroyTabs(){if(this.tabsGeneration!==-1){if(this.tabLabels.clear(),!this.visible)this.stack.invalidateAll();else{const e=this.tabs.value;this.stack.invalidateAll(t=>e.find(({id:n})=>n===t)!==void 0)}Me(this.tabBar),this.tabsGeneration=-1}}makeTabs(){const{tabBar:e,tabLabels:t,handleTabElement:n}=this;for(const{id:s,label:r,hidden:o}of this.tabs.value){if(o&&s!==this.selectedTab.value)continue;const a=document.createElement("div");a.classList.add("neuroglancer-tab-label"),a.textContent=r,a.addEventListener("click",()=>{this.selectedTab.value=s}),n!==void 0&&n(s,a),t.set(s,a),e.appendChild(a)}this.updateTabLabelStyles(),this.tabsGeneration=this.tabs.changed.count}disposed(){Me(this.tabBar),this.tabLabels.clear(),at(this.element),super.disposed()}}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const pf=Ae.fromObject({"shift?+mousedown0":{action:"set"},"shift?+alt+mousedown0":{action:"adjust-window-via-drag"},"shift?+wheel":{action:"zoom-via-wheel"}});function ff(i,e){const t=new fn(i);return In(t),t.addTextureSampler("sampler2D","uHistogramSampler",e),t.addOutputBuffer("vec4","out_color",0),t.addAttribute("uint","aDataValue"),t.addUniform("float","uBoundsFraction"),t.addVertexCode(` +float getCount(int i) { + return texelFetch(uHistogramSampler, ivec2(i, 0), 0).x; +} +vec4 getVertex(float cdf, int i) { + float x; + if (i == 0) { + x = -1.0; + } else if (i == 255) { + x = 1.0; + } else { + x = float(i) / 254.0 * uBoundsFraction * 2.0 - 1.0; + } + return vec4(x, cdf * (2.0 - uLineParams.y) - 1.0 + uLineParams.y * 0.5, 0.0, 1.0); +} +`),t.setVertexMain(` +int lineNumber = int(aDataValue); +int dataValue = lineNumber; +float cumSum = 0.0; +for (int i = 0; i <= dataValue; ++i) { + cumSum += getCount(i); +} +float total = cumSum + getCount(dataValue + 1); +float cumSumEnd = dataValue == ${pi-1} ? cumSum : total; +if (dataValue == ${pi-1}) { + cumSum + getCount(dataValue + 1); +} +for (int i = dataValue + 2; i < 256; ++i) { + total += getCount(i); +} +total = max(total, 1.0); +float cdf1 = cumSum / total; +float cdf2 = cumSumEnd / total; +emitLine(getVertex(cdf1, lineNumber), getVertex(cdf2, lineNumber + 1), 1.0); +`),t.setFragmentMain(` +out_color = vec4(0.0, 1.0, 1.0, getLineAlpha()); +`),t.build()}class gf extends T.O8{constructor(e,t,n,s){super(),this.element=e,this.dataType=t,this.getModel=n,this.setModel=s,e.title=pf.describe(),this.registerDisposer(new tn(e,pf)),Z(e,"set",r=>{const o=r.detail,a=this.getModel(),l=this.getTargetValue(o);if(l===void 0)return;const c=Ze(a.window,a.range),d=Bn(c,l),u=h=>{const p=this.getModel();this.setModel(Sr(p,"range",d,h))};u(l),zt(o,h=>{const p=this.getTargetValue(h);p!==void 0&&u(p)})}),Z(e,"adjust-window-via-drag",r=>{const o=r.detail,a=this.getTargetFraction(o),l=this.getWindowLerp(a),c=a<.5?0:1,d=u=>{const h=this.getModel();this.setModel(Sr(h,"window",c,u))};zt(o,u=>{const h=this.getModel().window,p=this.getTargetFraction(u);d(c===0?de([l,h[1]],this.dataType,-p/(1-p)):de([h[0],l],this.dataType,1/p))})}),Z(e,"zoom-via-wheel",r=>{const o=r.detail,a=_i(o),l=this.getTargetFraction(o),{dataType:c}=this,d=this.getModel(),u=de(d.window,c,l*(1-a)),h=de(d.window,c,(1-l)*a+l);this.setModel({...d,window:[u,h],range:d.range})})}getTargetFraction(e){const t=this.element.getBoundingClientRect();return(e.clientX-t.left)/t.width}getWindowLerp(e){return de(this.getModel().window,this.dataType,e)}getTargetValue(e){const t=this.getTargetFraction(e);if(Number.isFinite(t))return this.getWindowLerp(t)}}const mf=Symbol("histogramSamplerTexture");function Sr(i,e,t,n,s=!1){const r={...i},o=i[e];if(r[e]=[o[0],o[1]],r[e][t]=n,e==="window"&&rt(n,o[1-t])*(2*t-1)<0&&(r[e][1-t]=n),e==="range"&&s){const a=[i.window[0],i.window[1]];for(let l=0;l<2;++l)rt(n,a[l])*(2*l-1)>0&&(a[l]=n);r.window=a}return r}const pi=254+1;class mx extends nc{constructor(e){super(e.display,document.createElement("div"),e.visibility),this.parent=e,this.controller=this.registerDisposer(new gf(this.element,this.parent.dataType,()=>this.parent.trackable.value,n=>{this.parent.trackable.value=n})),this.dataValuesBuffer=this.registerDisposer(ci(this.gl,WebGL2RenderingContext.ARRAY_BUFFER,()=>{const n=new Uint8Array(pi*Ut);for(let s=0;s{const n=new fn(this.gl);return n.addAttribute("vec2","aVertexPosition"),n.addUniform("vec2","uBounds"),n.addUniform("vec4","uColor"),n.addOutputBuffer("vec4","out_color",0),n.setVertexMain(` +gl_Position = vec4(mix(uBounds[0], uBounds[1], aVertexPosition.x) * 2.0 - 1.0, aVertexPosition.y, 0.0, 1.0); +`),n.setFragmentMain(` +out_color = uColor; +`),n.build()})());const{element:t}=this;t.classList.add("neuroglancer-invlerp-cdfpanel")}get drawOrder(){return 100}drawIndirect(){const{lineShader:e,gl:t,regionShader:n,parent:{dataType:s,trackable:{value:r}}}=this;this.setGLLogicalViewport(),t.clearColor(0,0,0,0),t.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT),t.enable(WebGL2RenderingContext.BLEND),t.blendFunc(WebGL2RenderingContext.SRC_ALPHA,WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA),t.disable(WebGL2RenderingContext.DEPTH_TEST),t.disable(WebGL2RenderingContext.STENCIL_TEST);{n.bind(),t.uniform4f(n.uniform("uColor"),.2,.2,.2,1);const o=re(r.window,r.range[0]),a=re(r.window,r.range[1]),l=le(s,r.window);t.uniform2f(n.uniform("uBounds"),Math.min(o,a)*l,Math.max(o,a)*l+(1-l));const c=n.attribute("aVertexPosition");this.regionCornersBuffer.bindToVertexAttrib(c,2,WebGL2RenderingContext.FLOAT),t.drawArrays(WebGL2RenderingContext.TRIANGLE_FAN,0,4),t.disableVertexAttribArray(c)}if(this.parent.histogramSpecifications.producerVisibility.visible){const{renderViewport:o}=this;e.bind(),vn(e,{width:o.logicalWidth,height:o.logicalHeight},1);const a=e.textureUnit(mf);t.uniform1f(e.uniform("uBoundsFraction"),le(s,r.window)),t.activeTexture(WebGL2RenderingContext.TEXTURE0+a),t.bindTexture(WebGL2RenderingContext.TEXTURE_2D,this.parent.texture),di(t);const l=e.attribute("aDataValue");this.dataValuesBuffer.bindToVertexAttribI(l,1,WebGL2RenderingContext.UNSIGNED_BYTE),mn(t,pi,1),t.disableVertexAttribArray(l),t.bindTexture(WebGL2RenderingContext.TEXTURE_2D,null)}t.disable(WebGL2RenderingContext.BLEND)}isReady(){return!0}}function vx(){}class yx extends nc{constructor(e){super(e.display,document.createElement("div"),e.visibility),this.parent=e,this.cornersBuffer=ur(this.gl,-1,-1,1,1);const{element:t}=this;t.classList.add("neuroglancer-invlerp-legend-panel");const n=this.shaderOptions=e.legendShaderOptions;this.shaderGetter=Ai(this,this.gl,{...n,memoizeKey:{id:"colorLegendShader",base:n.memoizeKey},defineShader:(s,r,o)=>{s.addOutputBuffer("vec4","v4f_fragData0",0),s.addAttribute("vec2","aVertexPosition"),s.addUniform("float","uLegendOffset"),s.addVarying("float","vLinearPosition"),s.setVertexMain(` +gl_Position = vec4(aVertexPosition, 0.0, 1.0); +vLinearPosition = -uLegendOffset + ((aVertexPosition.x + 1.0) * 0.5) * (1.0 + 2.0 * uLegendOffset); +`);const a=this.parent.dataType,l=yt(a);s.addFragmentCode(zw(s,"ng_colorLegendLerp",a)),s.addFragmentCode(` +void emit(vec4 v) { + v4f_fragData0 = v; +} +${l} getDataValue() { + return ng_colorLegendLerp(vLinearPosition); +} +${l} getDataValue(int dummyChannel) { + return getDataValue(); +} +${l} getInterpolatedDataValue() { + return getDataValue(); +} +${l} getInterpolatedDataValue(int dummyChannel) { + return getDataValue(); +} +`),n.defineShader(s,r,o)}})}drawIndirect(){const e=this.shaderGetter(vx),{shader:t}=e;if(t===null)return;this.setGLLogicalViewport();const{gl:n}=this;n.clearColor(0,0,0,0),n.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT),t.bind(),this.shaderOptions.initializeShader(e),n.enable(WebGL2RenderingContext.BLEND);const{trackable:{value:{window:s}},dataType:r}=this.parent;Ni(t,"ng_colorLegendLerp",this.parent.dataType,s);const o=ie(r,s);n.uniform1f(t.uniform("uLegendOffset"),Number.isFinite(o)?o:0),n.blendFunc(WebGL2RenderingContext.SRC_ALPHA,WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA),n.disable(WebGL2RenderingContext.DEPTH_TEST),n.disable(WebGL2RenderingContext.STENCIL_TEST);const a=t.attribute("aVertexPosition");this.cornersBuffer.bindToVertexAttrib(a,2,WebGL2RenderingContext.FLOAT),n.drawArrays(WebGL2RenderingContext.TRIANGLE_FAN,0,4),n.disableVertexAttribArray(a)}isReady(){return!0}}function vf(i,e){const t=document.createElement("input");return t.addEventListener("focus",()=>{t.select()}),t.classList.add("neuroglancer-invlerp-widget-bound"),t.classList.add(`neuroglancer-invlerp-widget-${i}-bound`),t.type="text",t.spellcheck=!1,t.autocomplete="off",t.title=i==="range"?`Data value that maps to ${e}`:`${e===0?"Lower":"Upper"} bound for distribution`,t}function yf(i,e,t){const n=document.createElement("div");n.classList.add("neuroglancer-invlerp-widget-bounds"),n.classList.add(`neuroglancer-invlerp-widget-${i}-bounds`);const s=[vf(i,0),vf(i,1)];for(let o=0;o<2;++o){const a=s[o];a.addEventListener("input",()=>{Ec(a)}),a.addEventListener("change",()=>{const l=t.value,c=l[i];try{const d=qt(e,a.value);t.value=Sr(l,i,o,d,!0)}catch{br(a,c[o])}})}let r;return n.appendChild(s[0]),n.appendChild(s[1]),i==="range"&&(r=[document.createElement("div"),document.createElement("div"),document.createElement("div")],r[1].classList.add("neuroglancer-invlerp-widget-range-spacer"),n.insertBefore(r[0],s[0]),n.insertBefore(r[1],s[1]),n.appendChild(r[2])),{container:n,inputs:s,spacers:r}}function Ec(i){$t(i,Math.max(1,i.value.length+.1))}function br(i,e){let t;e instanceof P.R||Number.isInteger(e)?t=e.toString():t=e.toPrecision(6),i.value=t,Ec(i)}function Sf(i){const e=i.value,{range:t}=e;i.value={...e,range:[t[1],t[0]]}}function Sx(i,e,t){const n=e.value,s=de(n.range,i,.5-t/2),r=de(n.range,i,.5+t/2);e.value={...n,range:[s,r]}}function bx(i,e,t,n,s){const r=Math.exp(s),o=e.value,a=de(t,i,.5-r/2+n),l=de(t,i,.5+r/2+n);e.value={...o,range:[a,l]}}class bf extends Gt{constructor(e,t,n,s,r,o,a){super(e),this.display=t,this.dataType=n,this.trackable=s,this.histogramSpecifications=r,this.histogramIndex=o,this.legendShaderOptions=a,this.cdfPanel=this.registerDisposer(new mx(this)),this.boundElements={range:yf("range",this.dataType,this.trackable),window:yf("window",this.dataType,this.trackable)},this.registerDisposer(r.visibility.add(this.visibility));const{element:l,boundElements:c}=this;if(a!==void 0){const u=this.registerDisposer(new yx(this));l.appendChild(u.element)}const d=u=>{const h=Ne({svg:u,title:"Invert range",onClick:()=>{this.invertRange()}});return c.range.spacers[1].appendChild(h),h};this.invertArrows=[d(hf),d(uf)],l.appendChild(c.range.container),l.appendChild(this.cdfPanel.element),l.classList.add("neuroglancer-invlerp-widget"),l.appendChild(c.window.container),this.updateView(),this.registerDisposer(s.changed.add(this.registerCancellable((0,Qe.t)(()=>this.updateView()))))}get texture(){return this.histogramSpecifications.getFramebuffers(this.display.gl)[this.histogramIndex].colorBuffers[0].texture}invertRange(){Sf(this.trackable)}updateView(){const{boundElements:e}=this,{trackable:{value:t},dataType:n}=this;for(let u=0;u<2;++u)br(e.range.inputs[u],t.range[u]),br(e.window.inputs[u],t.window[u]);const s=rt(t.range[0],t.range[1])>0;e.range.container.style.flexDirection=s?"row-reverse":"row";const r=Ze(t.window,t.range),o=e.range.spacers,a=le(n,t.window),l=re(t.window,r[s?1:0])*a,c=re(t.window,r[s?0:1])*a+(1-a);o[s?2:0].style.width=`${l*100}%`,o[s?0:2].style.width=`${(1-c)*100}%`;const{invertArrows:d}=this;d[s?1:0].style.display="",d[s?0:1].style.display="none"}}class Cx extends Gt{constructor(e,t,n,s,r,o,a){super(e),this.display=t,this.watchableDataType=n,this.trackable=s,this.histogramSpecifications=r,this.histogramIndex=o,this.legendShaderOptions=a,this.invlerpWidget=this.makeInvlerpWidget(),this.registerDisposer(n.changed.add(()=>{Me(this.element),this.invlerpWidget.dispose(),this.invlerpWidget=this.makeInvlerpWidget()}))}get dataType(){return this.watchableDataType.value}disposed(){this.invlerpWidget.dispose(),super.disposed()}makeInvlerpWidget(){const{dataType:e}=this,t=new bf(this.visibility,this.display,e,this.trackable,this.histogramSpecifications,this.histogramIndex,this.legendShaderOptions);return this.element.appendChild(t.element),t}}const wx=Ae.fromObject({"at:shift+wheel":{action:"adjust-contrast-via-wheel"},"at:shift+mousedown0":{action:"adjust-via-drag"},"at:shift+mousedown2":{action:"invert-range"}});function Cf(i,e){i.bindInputEventMap(wx),i.bindAction("adjust-contrast-via-wheel",t=>{t.stopPropagation();const n=_i(t.detail);Sx(e.dataType,e.trackable,n)}),i.bindAction("adjust-via-drag",t=>{t.stopPropagation();let n=t.detail.screenX,s=t.detail.screenY,r=e.trackable.value.range,o=r,a=n,l=s;zt(t.detail,c=>{const d=e.trackable.value.range,u=c.screenX,h=c.screenY;Bt(e.dataType,d,o)||(r=d,n=a,s=l),bx(e.dataType,e.trackable,r,(h-s)*2/screen.height,(u-n)*4/screen.width),o=e.trackable.value.range,a=u,l=h})}),i.bindAction("invert-range",t=>{t.stopPropagation(),Sf(e.trackable)})}var wf=G(5061),xf=G(7349),Ef=G(350),xx=G(9575);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function No(i={}){return Ne({svg:xx,...i})}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */let zn=null,fi=null;const Ex=200;class pe{constructor(e=!1,t=!1){if(zn===null){zn=document.createElement("ul"),zn.id="statusContainer",zn.tabIndex=-1;const s=document.getElementById("neuroglancer-container");s?s.appendChild(zn):document.body.appendChild(zn)}if(t&&fi===null){fi=document.createElement("ul"),fi.id="statusContainerModal";const s=document.getElementById("neuroglancer-container");s?s.appendChild(fi):document.body.appendChild(fi)}const n=document.createElement("li");if(this.element=n,e===!0&&(e=Ex),e!==!1?(this.setVisible(!1),this.timer=window.setTimeout(this.setVisible.bind(this,!0),e)):this.timer=null,t){const s=document.createElement("div"),r=No({title:"Dismiss",onClick:()=>{this.dismissModal()}});r.classList.add("dismiss-modal"),r.addEventListener("click",()=>this.dismissModal()),s.appendChild(r),s.appendChild(n),this.modalElementWrapper=s,fi.appendChild(s)}else zn.appendChild(n)}dispose(){this.modalElementWrapper?fi.removeChild(this.modalElementWrapper):zn.removeChild(this.element),this.element=void 0,this.timer!==null&&clearTimeout(this.timer)}dismissModal(){this.modalElementWrapper&&(fi.removeChild(this.modalElementWrapper),this.modalElementWrapper=void 0,zn.appendChild(this.element))}setText(e,t){this.element.textContent=e,t&&this.setVisible(!0)}setHTML(e,t){this.element.innerHTML=e,t&&this.setVisible(!0)}setVisible(e){this.timer!==null&&(clearTimeout(this.timer),this.timer=null),this.element.style.display=e?"block":"none"}static forPromise(e,t){const n=new pe(t.delay);n.setText(t.initialMessage);const s=n.dispose.bind(n);return e.then(s,r=>{let o;r instanceof Error?o=r.message:o=""+r;const{errorPrefix:a=""}=t;n.setErrorMessage(a+o),n.setVisible(!0)}),e}setErrorMessage(e){this.element.textContent=e+" ";const t=document.createElement("button");t.textContent="Dismiss",t.addEventListener("click",()=>{this.dispose()}),this.element.appendChild(t)}static showMessage(e){const t=new pe;return t.element.textContent=e,t.setVisible(!0),t}static showTemporaryMessage(e,t=2e3){const n=pe.showMessage(e);return window.setTimeout(()=>n.dispose(),t),n}}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Tx=/^[A-Z]$/;class Tf extends T.O8{constructor(e,t){super(),this.tool=e,this.inputEventMapBinder=t}bindAction(e,t){this.registerDisposer(Z(window,e,t))}bindInputEventMap(e){this.inputEventMapBinder(e,this)}cancel(){const{globalBinder:e}=this.tool;this===e.activeTool_&&e.deactivate_()}}class Oo extends T.O8{constructor(e,t=!1){super(),this.localBinder=e,this.toggle=t,this.changed=new j.HN,this.keyBinding=void 0}get context(){return this.localBinder.context}get globalBinder(){return this.localBinder.globalBinder}unbind(){const{keyBinding:e}=this;e!==void 0&&this.localBinder.set(e,void 0)}}class gi extends Oo{constructor(e,t=!1){super(e.toolBinder,t),this.layer=e}get mouseState(){return this.layer.manager.root.layerSelectedValues.mouseState}}class Df extends T.O8{constructor(e){super(),this.layer=e,this.changed=new j.HN}get context(){return this.layer}get mouseState(){return this.layer.manager.root.layerSelectedValues.mouseState}deactivate(){}unbind(){const{layer:e}=this;e.tool.value===this&&(e.tool.value=void 0)}}function Tc(i,e){if(e===void 0)return;typeof e=="string"&&(e={type:e}),(0,f.Rf)(e);const t=(0,f.cQ)(e,"type",f.zr);let n=i,s;for(;;){if(n=Object.getPrototypeOf(n),n===null)throw new Error(`Invalid tool type: ${JSON.stringify(e)}.`);if(s=_o.get(n)?.get(t),s!==void 0)break}return s(i,e)}function Dx(i,e){if(e===void 0)return;typeof e=="string"&&(e={type:e}),(0,f.Rf)(e);const t=(0,f.cQ)(e,"type",f.zr),n=If.get(t);if(n===void 0)throw new Error(`Invalid tool type: ${JSON.stringify(e)}.`);return n(i,e)}const If=new Map,_o=new Map;function Cr(i,e){If.set(i,e)}function sn(i,e,t){const{prototype:n}=i;let s=_o.get(n);s===void 0&&(s=new Map,_o.set(n,s)),s.set(e,t)}function Ix(i,e){const{prototype:t}=i,n=_o.get(t);n&&n.delete(e)}class Lx extends T.O8{constructor(e){super(),this.layer=e,this.changed=new j.HN}get value(){return this.value_}set value(e){e!==this.value_&&(this.unregister(),e!==void 0&&(e.changed.add(this.changed.dispatch),this.value_=e),this.changed.dispatch())}unregister(){const e=this.value_;e!==void 0&&(e.changed.remove(this.changed.dispatch),e.dispose(),this.value_=void 0)}disposed(){this.unregister(),super.disposed()}restoreState(e){this.value=Dx(this.layer,e)}reset(){this.value=void 0}toJSON(){const e=this.value_;if(e!==void 0)return e.toJSON()}}class Rx extends T.O8{constructor(e){super(),this.inputEventMapBinder=e,this.bindings=new Map,this.changed=new j.HN,this.debounceDeactivate=this.registerCancellable((0,Fe.A)(()=>{this.deactivate_(),this.reactivateQueuedTool()},100))}get(e){return this.bindings.get(e)}set(e,t){const{bindings:n}=this,s=n.get(e);if(s!==void 0){s.keyBinding=void 0,n.delete(e);const r=s.localBinder;r.bindings.delete(e),r.jsonToKey.delete(JSON.stringify(s.toJSON())),this.destroyTool(s),r.changed.dispatch()}if(t!==void 0){const r=t.localBinder,o=JSON.stringify(t.toJSON()),a=r.jsonToKey.get(o);if(a!==void 0){const l=r.bindings.get(a);l.keyBinding=void 0,n.delete(a),r.bindings.delete(a),r.jsonToKey.delete(o),this.destroyTool(l)}r.bindings.set(e,t),t.keyBinding=e,r.jsonToKey.set(o,e),n.set(e,t),r.changed.dispatch()}this.changed.dispatch()}activate(e,t){if(t=t||this.get(e),t===void 0){this.deactivate_();return}this.debounceDeactivate.cancel();const n=this.activeTool_;if(t.toJSON()===n?.tool.toJSON()){t.toggle&&this.deactivate_();return}n!==void 0&&(n.tool.toggle&&!t.toggle&&(this.queuedTool=n.tool),this.deactivate_());const s=new Tf(t,this.inputEventMapBinder);if(this.activeTool_=s,!t.toggle){const r=`Key${e}`;s.registerEventListener(window,"keydown",o=>{o.stopPropagation(),o.preventDefault()}),s.registerEventListener(window,"keyup",o=>{o.code===r&&this.debounceDeactivate()}),s.registerEventListener(window,"blur",()=>{this.debounceDeactivate()})}return t.activate(s),t}reactivateQueuedTool(){if(this.queuedTool){const e=new Tf(this.queuedTool,this.inputEventMapBinder);this.activeTool_=e,this.queuedTool.activate(e),this.queuedTool=void 0}}destroyTool(e){this.queuedTool===e&&(this.queuedTool=void 0),this.activeTool_?.tool===e&&this.deactivate_(),e.dispose()}disposed(){this.deactivate_(),super.disposed()}deactivate_(){this.debounceDeactivate.cancel();const e=this.activeTool_;e!==void 0&&(this.activeTool_=void 0,e.dispose())}}class Dc extends T.O8{constructor(e,t){super(),this.context=e,this.globalBinder=t,this.bindings=new Map,this.jsonToKey=new Map,this.changed=new j.HN}disposed(){this.clear(),super.disposed()}get(e){return this.bindings.get(e)}set(e,t){this.globalBinder.set(e,t)}setJson(e,t){const n=Tc(this.context,t);n!==void 0&&this.set(e,n)}removeJsonString(e){const t=this.jsonToKey.get(e);t!==void 0&&this.set(t,void 0)}toJSON(){const{bindings:e}=this;if(e.size===0)return;const t={};for(const[n,s]of e)t[n]=s.toJSON();return t}deleteTool(e){const{globalBinder:t,bindings:n,jsonToKey:s}=this,r=n.get(e);r&&(n.delete(e),t.bindings.delete(e),s.delete(JSON.stringify(r.toJSON())),t.destroyTool(r),t.changed.dispatch(),this.changed.dispatch())}clear(){const{globalBinder:e,bindings:t}=this;if(t.size!==0){for(const[n,s]of t)s.keyBinding=void 0,e.bindings.delete(n),e.destroyTool(s);t.clear(),this.jsonToKey.clear(),e.changed.dispatch(),this.changed.dispatch()}}reset(){this.clear()}restoreState(e){if(e!==void 0){(0,f.Rf)(e);for(const[t,n]of Object.entries(e)){if(!t.match(Tx))throw new Error(`Invalid tool key: ${JSON.stringify(t)}`);const s=Tc(this.context,n);if(s===void 0)return;this.set(t,s)}}}}class Lf extends T.O8{constructor(e,t){super(),this.localBinder=e,this.toolJson=t,this.element=document.createElement("div"),this.toolJsonString=JSON.stringify(this.toolJson);const{element:n}=this;n.classList.add("neuroglancer-tool-key-binding"),this.registerDisposer(e.changed.add(this.registerCancellable((0,Qe.t)(()=>this.updateView())))),this.updateView(),n.title="click \u2192 bind key, dbclick \u2192 unbind",n.addEventListener("dblclick",()=>{this.localBinder.removeJsonString(this.toolJsonString)}),Rf(this,n,s=>this.localBinder.setJson(s,this.toolJson))}updateView(){const{localBinder:e}=this,t=e.jsonToKey.get(this.toolJsonString);this.element.textContent=t??" "}}function Rf(i,e,t){let n;e.addEventListener("mousedown",s=>{if(s.button!==0||n!==void 0)return;s.preventDefault(),s.stopPropagation(),n=new T.O8,i.registerDisposer(n),n.registerDisposer(new pe(!1)).setText("Press A-Z to bind key"),n.registerEventListener(window,"keydown",o=>{const{code:a}=o,l=a.match(/^Key([A-Z])$/);if(l===null)return;o.stopPropagation(),o.preventDefault();const c=l[1];t(c)},{capture:!0}),n.registerEventListener(window,"mouseup",o=>{o.button!==0||n===void 0||(o.preventDefault(),o.stopPropagation(),i.unregisterDisposer(n),n.dispose(),n=void 0)})}),e.addEventListener("click",s=>{s.preventDefault(),s.stopPropagation()})}function Wn(i,e,t){const n=document.createElement("div");n.classList.add("neuroglancer-tool-button"),n.appendChild(i.registerDisposer(new Lf(e,t.toolJson)).element);const s=document.createElement("div");s.classList.add("neuroglancer-tool-button-label");const r=t.label;return r!==void 0&&(s.textContent=r),t.title&&(s.title=t.title),n.appendChild(s),n}function kf(i){const e=i.registerDisposer(new pe(!1));e.element.classList.add("neuroglancer-tool-status");const t=document.createElement("div");t.classList.add("neuroglancer-tool-status-content"),e.element.appendChild(t);const{inputEventMapBinder:n}=i;return i.inputEventMapBinder=(s,r)=>{const o=document.createElement("div");o.textContent=s.describe(),o.classList.add("neuroglancer-tool-status-bindings"),e.element.appendChild(o),n(s,r)},{message:e,content:t}}function Vi(i){const{message:e,content:t}=kf(i),n=document.createElement("div");n.classList.add("neuroglancer-tool-status-header");const s=document.createElement("div");s.classList.add("neuroglancer-tool-status-header-container"),s.appendChild(n),t.appendChild(s);const r=document.createElement("div");return r.classList.add("neuroglancer-tool-status-body"),t.appendChild(r),{message:e,body:r,header:n}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function mi(i,e="text/plain"){let t=!1;const n=(0,T.K6)(document,"copy",s=>{const{clipboardData:r}=s;r!==null&&(r.setData(e,i),t=!0),s.stopPropagation(),s.preventDefault()},!0);try{document.execCommand("copy")}finally{n()}return t}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Vo=new _.B0(0);window.addEventListener("keydown",i=>{Vo.value=bc(i)}),window.addEventListener("keyup",i=>{Vo.value=bc(i)});const kx=new Set(["f1","f2","f3","f4","f5","f6","f7","f8","f9","f10","f11","f12","escape","pause"]),Px=new Set(["color","date","datetime","datetime-local","email","month","number","password","search","tel","text","time","url","week"]);class yn extends T.O8{constructor(e,t){super(),this.target=e,this.eventMap=t,this.modifierShortcutsAreGlobal=!0,this.allShortcutsAreGlobal=!1,this.allowSpaceKeyOnButtons=!1,this.shouldIgnore=void 0,this.registerEventListener(e,"keydown",this.handleKeyDown.bind(this),!1)}shouldIgnoreEvent(e,t){if(this.shouldIgnore?.(t))return!0;const n=t.target,{tagName:s}=n;if(n===this.target)return!1;const r=s==="TEXTAREA"||s==="INPUT"||s==="BUTTON"||s==="SELECT",o=!r&&(n.isContentEditable||n.ownerDocument&&n.ownerDocument.designMode==="on");return!r&&!o||this.allShortcutsAreGlobal||kx.has(e)?!1:o||this.modifierShortcutsAreGlobal&&(t.altKey||t.ctrlKey||t.metaKey)?!0:s==="INPUT"&&Px.has(n.type)?e!=="enter":s==="INPUT"||s==="BUTTON"?this.allowSpaceKeyOnButtons?!1:e==="space":!0}handleKeyDown(e){const t=Ax(e);this.shouldIgnoreEvent(t,e)||cf(t,e,e,this.eventMap)}}function Ax(i){return i.code.toLowerCase()}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class rn extends T.O8{constructor(e,t){super(),this.element=Ne({...t,onClick:()=>{e.value=!e.value}}),this.element.classList.add("neuroglancer-checkbox-icon"),this.element.classList.add(t.backgroundScheme==="dark"?"dark-background":"light-background");const n=()=>{const s=e.value;this.element.dataset.checked=s?"true":"false",this.element.title=(s?t.disableTitle:t.enableTitle)||""};this.registerDisposer(e.changed.add(n)),n()}}var Mx=G(3112);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Hn(i={}){return Ne({svg:Mx,...i})}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Nx extends T.O8{constructor(e){super(),this.redraw=e}}class Wt extends T.O8{constructor(e,t,n=new vt(vt.VISIBLE)){super(),this.model=e,this.render=t,this.visibility=n,this.element=document.createElement("div"),this.generation=-1,this.currentViewDisposer=void 0,this.debouncedUpdateView=this.registerCancellable((0,Qe.t)(()=>this.updateView())),this.debouncedForceUpdateView=()=>{this.generation=-1,this.debouncedUpdateView()},this.element.style.display="contents",this.registerDisposer(e.changed.add(this.debouncedUpdateView)),this.registerDisposer(n.changed.add(()=>{this.visible&&this.debouncedUpdateView()})),this.updateView()}get visible(){return this.visibility.visible}updateView(){if(!this.visible)return;const{model:e}=this,t=e.changed.count;if(t===this.generation)return;this.disposeCurrentView();const n=this.currentViewDisposer=new Nx(this.debouncedForceUpdateView);this.render(e.value,this.element,n),this.generation=t}disposeCurrentView(){const{currentViewDisposer:e}=this;e!==void 0&&e.dispose(),Me(this.element)}disposed(){this.disposeCurrentView(),super.disposed()}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Bo extends T.O8{constructor(e){super(),this.model=e,this.element=document.createElement("select"),this.valueIndexMap=new Map;const{element:t,valueIndexMap:n}=this;let s=0;for(const r of Object.keys(e.enumType))if(Number.isNaN(Number(r))){const o=document.createElement("option");o.textContent=o.value=r.toLowerCase(),t.appendChild(o),n.set(e.enumType[r],s),++s}this.registerDisposer(e.changed.add(()=>this.updateView())),this.registerEventListener(t,"change",()=>this.updateModel()),this.registerEventListener(t,"wheel",r=>{r.preventDefault(),r.stopPropagation(),this.adjustViaWheel(r)}),this.updateView()}adjustViaWheel(e){const{element:t}=this,{deltaY:n}=e;n>0?(t.selectedIndex=(t.options.length+t.selectedIndex-1)%t.options.length,this.updateModel()):n<0&&(t.selectedIndex=(t.options.length+t.selectedIndex+1)%t.options.length,this.updateModel())}updateView(){const{element:e}=this;e.selectedIndex=this.valueIndexMap.get(this.model.value)}updateModel(){this.model.restoreState(this.element.value)}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Ic extends T.O8{constructor(e,t={}){super(),this.model=e,this.element=document.createElement("label"),this.inputElement=document.createElement("input");let{validator:n,label:s}=t;const{element:r,inputElement:o}=this;n===void 0&&(e instanceof _.DN?n=e.validator:n=a=>a),this.validator=n,s!==void 0&&(r.textContent=s),r.appendChild(o),r.className="neuroglancer-number-input",o.type="text",this.registerDisposer(this.model.changed.add(()=>this.updateView())),this.registerEventListener(o,"change",()=>this.updateModel()),this.updateView()}updateView(){this.inputElement.value=""+this.model.value}updateModel(){let e=parseFloat(this.inputElement.value.trim());if(Number.isNaN(e)){this.updateView();return}try{e=this.validator(e),this.model.value=e}catch{this.updateView()}}disposed(){at(this.element),super.disposed()}}/** + * @license + * Copyright 2017-2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Pf(i,e,t,n){return Math.floor((i-e)*(n-1)/(t-e))}function Ox(i,e,t){const{boundingBoxes:n,bounds:s}=i;let[r,o]=_h(s,e);if(r=Math.floor(r),o=Math.floor(o-1),!Number.isFinite(r)||!Number.isFinite(o))return;const a=[],l=d=>Pf(d,r,o,t),{rank:c}=i;for(const d of n){const u=Bh(d,e,c);u!==void 0&&(u.lower=Math.max(0,l(u.lower)),u.upper=Math.min(t-1,l(Math.ceil(u.upper-1))),a.push(u))}return a.sort((d,u)=>{const h=d.lower-u.lower;return h!==0?h:u.upper-u.upper}),(0,F.U8)(a,(d,u)=>{if(u===0)return!0;const h=a[u-1];return h.lower!==d.lower||h.upper!==d.upper}),{lowerBound:r,upperBound:o,normalizedBounds:a}}class Af extends T.O8{constructor(e,t,n="column"){super(),this.position=e,this.dimensionId=t,this.orientation=n,this.element=document.createElement("div"),this.visible=!0,this.dragging=new _.B0(!1),this.tickWidth=this.orientation==="column"?10:5,this.barWidth=this.orientation==="column"?15:10,this.barRightMargin=this.orientation==="column"?10:2,this.canvasWidth=this.tickWidth+this.barWidth+this.barRightMargin;const s=this.element;s.classList.add("neuroglancer-position-dimension-plot"),s.dataset.orientation=n;const r=document.createElement("canvas"),o=r.getContext("2d"),a=document.createElement("div"),l=document.createElement("div");l.appendChild(a);const c=document.createTextNode("");a.appendChild(c);const d=document.createElement("div"),u=document.createElement("div");l.classList.add("neuroglancer-position-dimension-plot-lowerbound"),d.classList.add("neuroglancer-position-dimension-plot-upperbound"),u.classList.add("neuroglancer-position-dimension-plot-hoverposition"),s.appendChild(l),s.appendChild(d),s.appendChild(u),s.appendChild(r);let h,p,m;const g=()=>{const w=this.position.coordinateSpace.value,b=w.ids.indexOf(this.dimensionId);if(b===-1)return;let x;n==="column"?(x=100,r.width=this.canvasWidth,r.height=x,d.style.marginTop=`${x-1}px`):(x=r.clientWidth,r.width=x,r.height=this.canvasWidth);const E=Ox(w,b,x);if(E===void 0||w.bounds.lowerBounds[b]+1===w.bounds.upperBounds[b]){this.element.style.display="none",this.visible=!1;return}this.visible=!0;const{lowerBound:D,upperBound:I}=E;h=D,p=I,c.textContent=D.toString(),d.textContent=I.toString();let L,N,k;n!=="column"&&(N=a.clientWidth,k=d.clientWidth,L=Math.max(N,k)/2,r.style.marginLeft=`${L}px`,r.style.marginRight=`${L}px`,d.style.position="relative",d.style.left=`${x+L-k/2}px`,a.style.marginLeft=`${L-N/2}px`),this.drawDimensionBounds(r,o,E);const O=this.position.value[b],V=(X,ce)=>{if(X!==void 0&&X>=D&&Math.floor(X)<=I){o.fillStyle=ce;const oe=Pf(X,D,I,x);return n==="column"?o.fillRect(0,oe,this.canvasWidth,1):o.fillRect(oe,0,1,this.canvasWidth),oe}},z=V(O,"#f66"),Y=this.dragging.value;let Q=Y?z:V(m,"#66f");if(Q!==void 0){u.textContent=(Y?Math.floor(O):m).toString();const X=n==="column"?a.clientHeight:a.clientWidth,ce=n==="column"?d.clientHeight:d.clientWidth;let oe,Se,Ke;if(n!=="column"){oe=u.clientWidth,Q+=L,Q-=oe/2,Q=Math.max(0,Q);const $e=x+L-ce/2-oe;Se=Q>L+X/2,Ke=Q<$e}else Se=Q>X,Ke=Q{if(h===void 0||p===void 0)return;const b=r.getBoundingClientRect();let x;return n==="column"?x=(w.clientY-b.top)/b.height:x=(w.clientX-b.left)/b.width,x=Math.max(0,x),x=Math.min(1,x),Math.round(x*(p-h))+h},S=w=>{const b=this.position.coordinateSpace.value,x=b.ids.indexOf(this.dimensionId);if(x===-1)return;let E=y(w);if(E===void 0)return;const{position:D}=this,I=D.value;b.bounds.voxelCenterAtIntegerCoordinates[x]||(E+=.5),I[x]=E,D.value=I};r.addEventListener("pointermove",w=>{m=y(w),v()}),r.addEventListener("pointerleave",()=>{m=void 0,v()}),r.addEventListener("pointerdown",w=>{w.preventDefault(),w.stopPropagation(),!(w.ctrlKey||w.altKey||w.metaKey)&&(zt(w,b=>{this.wasDisposed||(m=void 0,S(b),v(),this.dragging.value=!0)},()=>{this.dragging.value=!1,v()}),S(w))}),g(),n==="row"&&(r.style.maxWidth="100%",r.style.justifySelf="stretch",new ResizeObserver(g).observe(r))}drawDimensionBounds(e,t,n){const{orientation:s}=this;t.clearRect(0,0,e.width,e.height);const{normalizedBounds:r}=n,o=s==="column"?l=>{t.fillRect(0,l,this.tickWidth,1)}:l=>{t.fillRect(l,0,1,this.tickWidth)};t.fillStyle="#fff";for(const{lower:l,upper:c}of r)o(l),o(c);const a=r.length;t.fillStyle="#ccc";for(let l=0;li.nameElement,i=>i.coordinate,i=>i.scaleElement];function Uo(i,e){const t=i.coordinateArrays[e];return t===void 0?t:i.units[e]!==""||i.scales[e]!==1?null:t}class Vx{constructor(e,t,n,s){this.coordinateSpace=e,this.id=t,this.container=document.createElement("div"),this.nameContainer=document.createElement("span"),this.nameElement=document.createElement("input"),this.scaleContainer=document.createElement("span"),this.scaleElement=document.createElement("input"),this.coordinate=document.createElement("input"),this.coordinateLabel=document.createElement("span"),this.playButton=document.createElement("div"),this.pauseButton=document.createElement("div"),this.coordinateLabelWidth=0,this.maxPositionWidth=0,this.maxPositionWidthSeen=0,this.dropdownOwner=void 0,this.modified=!1,this.draggingPosition=!1,this.hasFocus=!1;const{container:r,scaleElement:o,scaleContainer:a,coordinate:l,nameElement:c,nameContainer:d,coordinateLabel:u,playButton:h,pauseButton:p}=this;r.title="",r.classList.add("neuroglancer-position-dimension");const{allowFocus:m,showPlayback:g}=s;m&&(r.draggable=!0,r.tabIndex=-1),r.appendChild(d),r.appendChild(o),d.appendChild(c),d.title="Drag to reorder, double click to rename. Names ending in ' or ^ indicate dimensions local to the layer; names ending in ^ indicate channel dimensions (image layers only).",a.appendChild(o),c.classList.add("neuroglancer-position-dimension-name"),c.disabled=!0,c.spellcheck=!1,c.autocomplete="off",c.required=!0,c.placeholder=" ",a.classList.add("neuroglancer-position-dimension-scale-container"),o.classList.add("neuroglancer-position-dimension-scale"),o.disabled=!0,o.spellcheck=!1,o.autocomplete="off",r.appendChild(a),g&&(h.classList.add("neuroglancer-icon"),p.classList.add("neuroglancer-icon"),h.innerHTML=xf,p.innerHTML=wf,r.appendChild(h),r.appendChild(p)),r.appendChild(l),l.type="text",l.classList.add("neuroglancer-position-dimension-coordinate"),l.spellcheck=!1,l.autocomplete="off",l.pattern=String.raw`(-?\d+(?:\.(?:\d+)?)?)`;const v=Uo(e,n);if(v!=null){let y=0;for(const S of v.labels)y=Math.max(y,S.length);this.coordinateLabelWidth=y,u.style.width=`${y+2}ch`,r.appendChild(u)}l.required=!0,l.placeholder=" ",u.classList.add("neuroglancer-position-dimension-coordinate-label"),m&&(d.addEventListener("dblclick",()=>{c.disabled=!1,c.focus(),c.select()}),a.addEventListener("dblclick",()=>{o.disabled=!1,o.focus(),o.select()}),l.addEventListener("focus",()=>{l.select()}),r.addEventListener("click",y=>{(!(y.target instanceof HTMLInputElement)||y.target.disabled)&&l.focus()}))}}function Nf(i,e){const t=e.length;t>i.maxPositionWidthSeen&&(i.maxPositionWidthSeen=t),$t(i.coordinate,Math.max(Math.min(i.maxPositionWidth,i.maxPositionWidthSeen),t))}function Of(i){const{value:e}=i;$t(i),i.parentElement.dataset.isEmpty=e===""?"true":"false"}class xs extends T.O8{constructor(e,t,{copyButton:n=!0,velocity:s=void 0,singleDimensionId:r=void 0,getToolBinder:o=void 0,allowFocus:a=!0,showPlayback:l=!0}={}){super(),this.position=e,this.combiner=t,this.element=document.createElement("div"),this.dimensionContainer=document.createElement("div"),this.coordinateSpace=void 0,this.dimensionWidgets=new Map,this.dimensionWidgetList=[],this.dragSource=void 0;const{element:c,dimensionContainer:d}=this;if(this.velocity=s,this.singleDimensionId=r,this.getToolBinder=o,this.allowFocus=a,this.showPlayback=l,this.registerDisposer(e.coordinateSpace.changed.add(this.registerCancellable((0,Qe.t)(()=>this.updateDimensions())))),c.className="neuroglancer-position-widget",d.style.display="contents",c.appendChild(d),n){const m=Hn({title:"Copy position to clipboard",onClick:()=>{const g=mi(this.getPositionText());pe.showTemporaryMessage(g?"Position copied to clipboard":"Failed to copy position to clipboard")}});m.addEventListener("dragstart",g=>{g.dataTransfer.setData(Fo,JSON.stringify({position:e.toJSON(),dimensions:e.coordinateSpace.value.names})),g.dataTransfer.setData("text",this.getPositionText()),g.stopPropagation()}),m.draggable=!0,c.appendChild(m)}const u=this.registerCancellable((0,Qe.t)(()=>this.updateView()));this.registerDisposer(e.changed.add(u)),s!==void 0&&this.registerDisposer(s.changed.add(u));const h=m=>{const g=m.target;return!!(g instanceof Element&&g.matches(".neuroglancer-position-dimension-playback *"))};if(a){const m=this.registerDisposer(new yn(c,Mf));m.allShortcutsAreGlobal=!0,m.shouldIgnore=h}const p=this.registerDisposer(new tn(c,Mf));p.shouldIgnore=h,this.registerDisposer(Z(c,"cancel",m=>{this.coordinateSpace=void 0,this.updateView(),this.closeDropdown();const{target:g}=m;g instanceof HTMLElement&&g.blur()})),this.updateView()}getDimensionIndex(e){return this.position.coordinateSpace.value.ids.indexOf(e)}openRegularDropdown(e,t){t.classList.add("neuroglancer-position-dimension-dropdown");const n=e.dropdownOwner,s=this.getToolBinder?.();if(s!==void 0){const a=this.getDimensionIndex(e.id),l=Wn(n,s,{toolJson:{type:wr,dimension:e.coordinateSpace.names[a]}});t.appendChild(l)}const r=n.registerDisposer(new Af(this.position,e.id));t.appendChild(r.element);const o=this.velocity?.dimensionVelocity(n,e.id);if(o!==void 0){const a=document.createElement("div");a.classList.add("neuroglancer-position-dimension-playback");const l=document.createElement("div");l.classList.add("neuroglancer-position-dimension-playback-header"),a.appendChild(l),l.appendChild(n.registerDisposer(new rn(this.velocity.playbackEnabled(e.id),{svg:Ef,enableTitle:"Enable playback/velocity",disableTitle:"Disable playback/velocity",backgroundScheme:"dark"})).element),l.appendChild(document.createTextNode("Playback")),t.appendChild(a);const c=n.registerDisposer((0,_.Uq)(d=>d!==void 0,[o]));a.appendChild(n.registerDisposer(new Wt(c,(d,u,h)=>{if(!d)return;const p=new _.B0(0);p.changed.add(()=>{const b=p.value,x=o.value;x!==void 0&&x.velocity!==b&&(o.value={...x,velocity:b})});const m=Ne({text:"\xB1",title:"Negate velocity",onClick:()=>{p.value=-p.value}}),g=h.registerDisposer(new Ic(p));g.element.insertBefore(m,g.element.firstChild),g.element.title="Velocity in coordinates per second";const v=document.createElement("span");v.textContent="/s",g.element.appendChild(v),u.appendChild(g.element);const y=new Oi.F(Gn,Gn.STOP),S=()=>{y.value=o.value?.atBoundary??Gn.STOP,p.value=o.value?.velocity??0};S(),h.registerDisposer(o.changed.add(S)),y.changed.add(()=>{const b=y.value,x=o.value;x!==void 0&&x.atBoundary!==b&&(o.value={...x,atBoundary:b})});const w=new Bo(y).element;u.appendChild(w),w.title="Behavior when lower/upper bound is reached"})).element)}r.dragging.changed.add(()=>{(e.draggingPosition=r.dragging.value)===!1&&this.updateDropdownVisibility(e)})}openCoordinateArrayDropdown(e,t,n){t.classList.add("neuroglancer-position-dimension-coordinate-dropdown");const{coordinates:s,labels:r}=n,o=[],a=s.length;t.style.setProperty("--neuroglancer-coordinate-label-width",`${e.coordinateLabelWidth}ch`);for(let l=0;l{const h=this.getDimensionIndex(e.id);if(h===-1)return;const{position:p}=this,m=p.value;m[h]=s[l]+.5,e.modified=!1,p.value=m}),t.appendChild(c),o.push({entryElement:c,coordinateElement:d,labelElement:u})}}openDropdown(e){if(e.dropdownOwner!==void 0)return;const t=this.getDimensionIndex(e.id);if(t===-1)return;this.closeDropdown();const n=e.dropdownOwner=new T.O8,s=document.createElement("div");s.draggable=!0,s.addEventListener("dragstart",o=>{o.stopPropagation(),o.preventDefault()}),s.addEventListener("pointerenter",()=>{e.hasFocus=!0}),s.tabIndex=-1,e.container.appendChild(s);const r=Uo(e.coordinateSpace,t);r==null?this.openRegularDropdown(e,s):this.openCoordinateArrayDropdown(e,s,r),this.widgetWithOpenDropdown=e,n.registerDisposer(()=>{at(s),e.dropdownOwner=void 0,e.container.dataset.dropdownVisible=void 0,this.widgetWithOpenDropdown=void 0}),n.registerEventListener(document,"pointerdown",o=>{const{target:a}=o;a instanceof Node&&e.container.contains(a)||this.closeDropdown(e)},{capture:!0})}closeDropdown(e=this.widgetWithOpenDropdown){if(e===void 0)return;const{dropdownOwner:t}=e;t!==void 0&&t.dispose()}pasteString(e,t){for(;;){e.coordinate.focus();const n=t.match(/^\s*(-?\d+(?:\.(?:\d+)?)?)((?:\s+(?![\s,]))|(?:\s*,\s*))?/);if(n===null)break;if(n[1]!==void 0&&document.execCommand("insertText",void 0,n[1]),n[2]!==void 0){const{dimensionWidgetList:s}=this,r=s.indexOf(e);if(r===-1||r+1===s.length)break;const o=t.substring(n[0].length);e=s[r+1],t=o;continue}break}}reorderDimensionTo(e,t){if(e===t)return;const{coordinateSpace:n}=this.position;n.value=Qh(n.value,e,t)}updateDropdownVisibility(e){e.hasFocus||e.draggingPosition?this.openDropdown(e):this.closeDropdown(e)}newDimension(e,t,n){const s=new Vx(e,t,n,{allowFocus:this.allowFocus,showPlayback:this.showPlayback});this.singleDimensionId===void 0&&(s.container.addEventListener("dragstart",r=>{this.dragSource=s,r.stopPropagation(),r.dataTransfer.setData("neuroglancer-dimension","")}),s.container.addEventListener("dragenter",r=>{const{dragSource:o}=this;if(o===void 0||o===s)return;const{dimensionWidgetList:a}=this,l=a.indexOf(o),c=a.indexOf(s);l===-1||c===-1||(r.preventDefault(),this.reorderDimensionTo(c,l))}),s.container.addEventListener("dragend",r=>{this.dragSource===s&&(this.dragSource=void 0)})),this.allowFocus?(s.container.addEventListener("focusin",()=>{s.hasFocus=!0,this.updateDropdownVisibility(s)}),s.container.addEventListener("focusout",r=>{const{relatedTarget:o}=r;o instanceof Node&&s.container.contains(o)||(s.hasFocus=!1,this.updateDropdownVisibility(s))}),s.coordinate.addEventListener("paste",r=>{const o=s.coordinate,a=o.value,{clipboardData:l}=r;if(l===null)return;let c=l.getData("text"),{selectionEnd:d,selectionStart:u}=o;if(u!==0||d!==a.length){u==null&&(u=0),d==null&&(d=0);const h=c.match(/[^\-0-9.]/);h!==null&&(c=c.substring(0,h.index)),c.length>0&&document.execCommand("insertText",void 0,c)}else this.pasteString(s,c);r.preventDefault(),r.stopPropagation()}),s.coordinate.addEventListener("input",()=>{s.modified=!0;const r=s.coordinate,o=r.value;let{selectionDirection:a,selectionEnd:l,selectionStart:c}=r;c===null&&(c=0),l===null&&(l=c);let d="";const u=/[^\-0-9.]/g;d+=o.substring(0,c).replace(u,"");const h=d.length;d+=o.substring(c,l).replace(u,"");const p=d.length;d+=o.substring(l).replace(u,""),r.value=d,r.selectionStart=h,r.selectionEnd=p,r.selectionDirection=a,Nf(s,d),l===c&&l===o.length&&o.match(/^(-?\d+(?:\.(?:\d+)?)?)((?:\s+(?![\s,]))|(?:\s*,\s*))$/)&&this.selectAdjacentCoordinate(s,1)}),s.nameElement.addEventListener("input",()=>{const{nameElement:r}=s;$t(r),this.updateNameValidity()}),s.scaleElement.addEventListener("input",()=>{const{scaleElement:r}=s;Of(r),this.updateScaleValidity(s)}),s.coordinate.addEventListener("blur",r=>{const{relatedTarget:o}=r;this.dimensionWidgetList.some(a=>a.coordinate===o)||s.modified&&this.updatePosition()}),s.nameElement.addEventListener("blur",r=>{s.nameElement.disabled=!0;const{relatedTarget:o}=r;this.dimensionWidgetList.some(a=>a.nameElement===o)||this.updateNames()||this.forceUpdateDimensions()}),s.scaleElement.addEventListener("blur",r=>{s.scaleElement.disabled=!0;const{relatedTarget:o}=r;this.dimensionWidgetList.some(a=>a.scaleElement===o)||this.updateScales()||this.forceUpdateDimensions()})):s.coordinate.disabled=!0,Z(s.container,"adjust-via-wheel",r=>{const o=r.detail,{deltaY:a}=o;a!==0&&this.adjustDimensionPosition(s.id,Math.sign(a))}),Z(s.container,"adjust-velocity-via-wheel",r=>{const o=r.detail;this.adjustDimensionVelocity(s,_i(o))}),Z(s.container,"adjust-up",()=>{this.adjustDimensionPosition(s.id,-1)}),Z(s.container,"adjust-down",()=>{this.adjustDimensionPosition(s.id,1)});for(const r of _x){const o=r(s);Z(o,"maybe-tab-forward",a=>{this.handleLeftRightMovement(a,s,1,r)}),Z(o,"maybe-tab-backward",a=>{this.handleLeftRightMovement(a,s,-1,r)}),Z(o,"tab-forward",()=>{this.selectAdjacentField(s,1,r)}),Z(o,"tab-backward",()=>{this.selectAdjacentField(s,-1,r)})}if(Z(s.coordinate,"commit",()=>{this.updatePosition()}),Z(s.nameElement,"commit",()=>{this.updateNames()}),Z(s.scaleElement,"commit",()=>{this.updateScales()}),Z(s.coordinate,"delete-backward",r=>{r.stopPropagation();const{coordinate:o}=s;o.selectionStart===o.selectionEnd&&o.selectionStart===0&&(r.preventDefault(),this.selectAdjacentCoordinate(s,-1))}),this.showPlayback){const r=o=>{this.velocity?.togglePlayback(s.id,o)};s.playButton.addEventListener("click",()=>r(!1)),s.pauseButton.addEventListener("click",()=>r(!0))}return s}forceUpdateDimensions(){let{position:{coordinateSpace:{value:e}}}=this;e.valid||(e=Fn),this.coordinateSpace=e;const{dimensionWidgets:t,dimensionWidgetList:n}=this;n.length=0;const{names:s,ids:r,scales:o,units:a,bounds:{lowerBounds:l,upperBounds:c}}=e,d=(h,p)=>{const m=l[p],g=c[p],v=Math.max(Number.isFinite(m)?Math.floor(m).toString().length:0,Number.isFinite(g)?Math.ceil(g).toString().length:0);let y=t.get(h);y===void 0?(y=this.newDimension(e,h,p),t.set(h,y),y.maxPositionWidthSeen=v):y.coordinateSpace=e,y.maxPositionWidth=v;const S=s[p];y.nameElement.value=S,y.nameElement.dataset.isValid=void 0,$t(y.nameElement);const w=Uo(e,p);w===void 0?y.container.dataset.coordinateArray="none":w===null?y.container.dataset.coordinateArray="invalid":y.container.dataset.coordinateArray="valid",y.scaleContainer.title="Drag to reorder, double click to change scale",w===null&&(y.scaleContainer.title+=". Coordinate array disabled. To use the coordinate array, remove the unit/scale.");const{scale:b,prefix:x,unit:E}=kh(o[p],a[p]),D=`${b}${x}${E}`;return y.scaleElement.value=D,y.scaleElement.dataset.isValid=void 0,Of(y.scaleElement),n.push(y),y.container},{singleDimensionId:u}=this;if(u!==void 0){const h=this.getDimensionIndex(u);h===-1?nn(this.dimensionContainer,[]):nn(this.dimensionContainer,[d(u,h)])}else nn(this.dimensionContainer,r.map(d));for(const[h,p]of t)p.coordinateSpace!==e&&(this.closeDropdown(p),t.delete(h))}updateDimensions(){const{position:{coordinateSpace:{value:e}}}=this;e!==this.coordinateSpace&&this.forceUpdateDimensions()}selectAdjacentField(e,t,n){const{dimensionWidgetList:s}=this;let r=s.indexOf(e);if(r!==-1)for(;;){if(r+=t,r<0||r>=s.length)return!1;const o=s[r],a=n(o);if(a.style.display!=="none")return a.disabled=!1,a.focus(),a.selectionStart=0,a.selectionEnd=a.value.length,a.selectionDirection=t===1?"forward":"backward",!0}}selectAdjacentCoordinate(e,t){return this.selectAdjacentField(e,t,n=>n.coordinate)}handleLeftRightMovement(e,t,n,s){e.stopPropagation();const r=s(t);r.selectionStart!==r.selectionEnd||r.selectionStart!==(n===1?r.value.length:0)||this.selectAdjacentField(t,n,s)&&e.preventDefault()}updateNameValidity(){const{dimensionWidgetList:e}=this,t=e.map(r=>r.nameElement.value),n=t.length,s=this.combiner.getRenameValidity(t);for(let r=0;rl.nameElement.value);if(this.combiner.getRenameValidity(s).includes(!1))return!1;const r=n.names;if((0,F.r1)(r,s))return!1;const o=n.timestamps.map((l,c)=>r[c]===s[c]?l:Date.now()),a={...n,names:s,timestamps:o};return t.value=a,!0}updateScales(){if(!this.allowFocus)return;const{dimensionWidgetList:e}=this,{position:{coordinateSpace:t}}=this,n=t.value,s=e.map(u=>sr(u.scaleElement.value));if(s.includes(void 0))return!1;const r=Float64Array.from(s,u=>u.scale),o=Array.from(s,u=>u.unit),{scales:a,units:l}=n;if((0,F.r1)(a,r)&&(0,F.r1)(l,o))return!1;const c=n.timestamps.map((u,h)=>r[h]===a[h]&&o[h]===l[h]?u:Date.now()),d=Oe({valid:n.valid,rank:n.rank,scales:r,units:o,timestamps:c,ids:n.ids,names:n.names,boundingBoxes:n.boundingBoxes,coordinateArrays:n.coordinateArrays});return t.value=d,!0}getPositionText(){const{position:e}=this;return e.valid?e.value.map(t=>Math.floor(t)).join(", "):""}updateView(){this.updateDimensions();const{position:{value:e},dimensionWidgetList:t}=this,n=t.length;if(e===void 0)return;const s=this.coordinateSpace,{velocity:r}=this;for(let o=0;ov-y);g!==m.length&&(h=u.labels[g])}const p=a.coordinateLabel;if(p.textContent=h,this.showPlayback){const m=r?.value?.[o];if(m!==void 0){const g=m.paused;a.playButton.style.display=g?"":"none",a.pauseButton.style.display=g?"none":""}else a.playButton.style.display="none",a.pauseButton.style.display="none"}}}disposed(){this.closeDropdown(),at(this.element),super.disposed()}}class Bx extends T.O8{constructor(e,t,n){super(),this.element=e,this.mouseState=t,this.coordinateSpace=n,this.tempPosition=C.eR.create(),e.className="neuroglancer-mouse-position-widget";const s=this.registerCancellable((0,Qe.t)(()=>this.updateView()));this.registerDisposer(t.changed.add(s)),this.registerDisposer(n.changed.add(s))}updateView(){let e="";const{mouseState:t,coordinateSpace:{value:n}}=this;if(t.active&&n!==void 0){const s=t.position,{rank:r,names:o}=n;for(let a=0;a{const r=this.coordinateSpace.value,o=this.dimensionIndex=this.coordinateSpace.value.ids.indexOf(t);if(o===-1){this.unbind();return}const a=r.names[o];this.dimensionName!==a&&(this.dimensionName=a,this.changed.dispatch())}))}get position(){return this.viewer.position}get velocity(){return this.viewer.velocity}get coordinateSpace(){return this.viewer.coordinateSpaceCombiner.combined}activate(e){const{viewer:t}=this,{content:n}=kf(e);n.classList.add("neuroglancer-position-tool"),e.bindInputEventMap(Fx);const s=new xs(t.position,t.coordinateSpaceCombiner,{velocity:t.velocity,singleDimensionId:this.dimensionId,copyButton:!1,allowFocus:!1,showPlayback:!1});s.element.style.userSelect="none",n.appendChild(e.registerDisposer(s).element);const r=e.registerDisposer(new Af(t.position,this.dimensionId,"row"));r.element.style.flex="1",n.appendChild(r.element),e.bindAction("adjust-position-via-wheel",l=>{l.stopPropagation();const c=l.detail,{deltaY:d}=c;d!==0&&s.adjustDimensionPosition(this.dimensionId,Math.sign(d))});const o=this.velocity.dimensionVelocity(e,this.dimensionId),a=e.registerDisposer((0,_.Uq)(l=>l!==void 0,[o]));n.appendChild(e.registerDisposer(new Wt(a,(l,c,d)=>{if(!l)return;c.classList.add("neuroglancer-position-dimension-playback");const u=document.createElement("div"),h=document.createElement("div");u.classList.add("neuroglancer-icon"),h.classList.add("neuroglancer-icon"),u.innerHTML=xf,h.innerHTML=wf,c.appendChild(u),c.appendChild(h);const p=()=>t.velocity.togglePlayback(this.dimensionId);u.addEventListener("click",p),h.addEventListener("click",p);const m=()=>{const E=o.value?.paused;u.style.display=E?"":"none",h.style.display=E?"none":""};d.registerDisposer(o.changed.add(m)),m();const g=new _.B0(0);g.changed.add(()=>{const E=g.value,D=o.value;D!==void 0&&D.velocity!==E&&(o.value={...D,velocity:E})});const v=Ne({text:"\xB1",title:"Negate velocity",onClick:()=>{g.value=-g.value}}),y=d.registerDisposer(new Ic(g));y.inputElement.disabled=!0,y.element.insertBefore(v,y.element.firstChild),y.element.title="Velocity in coordinates per second";const S=document.createElement("span");S.textContent="/s",y.element.appendChild(S),c.appendChild(y.element);const w=new Oi.F(Gn,Gn.STOP),b=()=>{w.value=o.value?.atBoundary??Gn.STOP,g.value=o.value?.velocity??0};b(),d.registerDisposer(o.changed.add(b)),w.changed.add(()=>{const E=w.value,D=o.value;D!==void 0&&D.atBoundary!==E&&(o.value={...D,atBoundary:E})});const x=new Bo(w).element;c.appendChild(x),x.title="Behavior when lower/upper bound is reached"})).element),n.appendChild(e.registerDisposer(new rn(t.velocity.playbackEnabled(this.dimensionId),{svg:Ef,enableTitle:"Enable playback/velocity",disableTitle:"Disable playback/velocity",backgroundScheme:"dark"})).element),e.bindAction("adjust-velocity-via-wheel",l=>{l.stopPropagation();const c=_i(l.detail);t.velocity.multiplyVelocity(this.dimensionId,c)}),e.bindAction("toggle-playback",l=>{l.stopPropagation(),t.velocity.togglePlayback(this.dimensionId)})}get description(){return`dim ${this.dimensionName}`}toJSON(){return{type:wr,dimension:this.dimensionName}}}function Lc(i,e){const t=(0,f.cQ)(e,"dimension",f.zr),n=i.coordinateSpaceCombiner.combined.value,s=n.names.indexOf(t);if(s===-1)throw new Error(`Invalid dimension name: ${JSON.stringify(t)}`);return new Ux(i,n.ids[s])}function $x(i){sn(i,wr,(e,t)=>Lc({position:e.position,velocity:e.velocity,coordinateSpaceCombiner:e.layerSpecification.coordinateSpaceCombiner,toolBinder:e.toolBinder},t))}function Gx(i){sn(i,wr,(e,t)=>Lc({position:e.localPosition,velocity:e.localVelocity,coordinateSpaceCombiner:e.localCoordinateSpaceCombiner,toolBinder:e.toolBinder},t))}function zx(i){sn(i,wr,(e,t)=>Lc({position:e.viewerNavigationState.position.value,velocity:e.viewerNavigationState.velocity.velocity,coordinateSpaceCombiner:e.layerSpecification.root.coordinateSpaceCombiner,toolBinder:e.toolBinder},t))}/** + * @license + * Copyright 2024 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const $o=512,xr=4,_f=4,Rc=.05,Go=.05,Vf=Symbol("transferFunctionSamplerTexture"),Bf=Symbol("histogramSamplerTexture"),Ff={[R.UINT8]:256,[R.INT8]:256,[R.UINT16]:8192,[R.INT16]:8192,[R.UINT32]:8192,[R.INT32]:8192,[R.UINT64]:8192,[R.FLOAT32]:8192};class Ln{constructor(e,t=C.yb){this.inputValue=e,this.outputColor=t}normalizedInput(e){return re(e,this.inputValue)}transferFunctionIndex(e,t){return Math.floor(this.normalizedInput(e)*(t-1))}interpolateColor(e,t){const n=C.ln.create();for(let s=0;s<4;++s)n[s]=de([this.outputColor[s],e.outputColor[s]],R.UINT8,t);return n}static copyFrom(e){const t=e.inputValue,n=C.ln.clone(e.outputColor);return new Ln(t,n)}}class zo{constructor(e=[],t,n=!0){this.controlPoints=e,this.dataType=t,this.autoComputeRange=n,this.controlPoints=e,this.range=he[t],this.sortAndComputeRange()}get length(){return this.controlPoints.length}addPoint(e){const{inputValue:t,outputColor:n}=e,s=this.controlPoints.findIndex(o=>o.inputValue===t);s!==-1&&this.updatePointColor(s,n);const r=new Ln(t,n);this.controlPoints.push(r),this.sortAndComputeRange()}removePoint(e){this.controlPoints.splice(e,1),this.computeRange()}updatePoint(e,t){this.controlPoints[e]=t;const n=t.inputValue,s=t.outputColor;this.sortAndComputeRange();for(let r=0;rt.normalizedInput(this.range)),e,(t,n)=>t-n)}sortAndComputeRange(){this.controlPoints.sort((e,t)=>e.normalizedInput(this.range)-t.normalizedInput(this.range)),this.computeRange()}computeRange(){if(this.autoComputeRange)if(this.controlPoints.length==0)this.range=he[this.dataType];else if(this.controlPoints.length===1){let e=he[this.dataType][1];this.dataType===R.FLOAT32&&e<=this.controlPoints[0].inputValue&&(e=this.controlPoints[0].inputValue+1),this.range=[this.controlPoints[0].inputValue,e]}else this.range=[this.controlPoints[0].inputValue,this.controlPoints[this.controlPoints.length-1].inputValue];this.range[0]===this.range[1]&&(this.range=he[this.dataType])}copy(){const e=new zo([],this.dataType,this.autoComputeRange);return e.range=this.range,e.controlPoints=this.controlPoints.map(t=>Ln.copyFrom(t)),e}}class Es{constructor(e){this.lookupTableSize=e,this.outputValues=new Uint8Array(e*xr).fill(0)}resize(e){this.lookupTableSize=e,this.outputValues=new Uint8Array(e*xr).fill(0)}updateFromControlPoints(e,t=void 0){const n=t||e.range,{controlPoints:s}=e,r=this.outputValues,o=this.lookupTableSize;function a(u,h){r[u]=h[0],r[u+1]=h[1],r[u+2]=h[2],r[u+3]=h[3]}function l(u){return u.transferFunctionIndex(n,o)}if(s.length===0){r.fill(0);return}const c=l(s[0]);if(c>0){const u=C.ln.fromValues(0,0,0,0);for(let h=0;h=v&&d++}}}static equal(e,t){return(0,F.r1)(e.outputValues,t.outputValues)}copy(){const e=new Es(this.lookupTableSize);return e.outputValues.set(this.outputValues),e}}class Wx extends T.O8{constructor(e,t,n=Ff[e]){super(),this.dataType=e,this.trackable=t,this.lookupTable=new Es(n),this.updateLookupTable()}get sortedControlPoints(){return this.trackable.value.sortedControlPoints}get range(){return this.sortedControlPoints.range}get size(){return this.lookupTable.lookupTableSize}updateLookupTable(e=void 0){this.lookupTable.updateFromControlPoints(this.sortedControlPoints,e)}addPoint(e){this.sortedControlPoints.addPoint(e)}updatePoint(e,t){return this.sortedControlPoints.updatePoint(e,t)}removePoint(e){this.sortedControlPoints.removePoint(e)}updatePointColor(e,t){this.sortedControlPoints.updatePointColor(e,t)}findNearestControlPointIndex(e,t){const n=de(t,this.dataType,e);return this.sortedControlPoints.findNearestControlPointIndex(n)}}class Uf extends T.O8{constructor(e){super(),this.gl=e,this.texture=null,this.height=1,this.priorOptions=void 0}updateAndActivate(e){const{gl:t}=this;if(t===null)return;let{texture:n}=this;function s(o,a){if(a===void 0)throw new Error("Texture unit must be defined for transfer function texture");o.activeTexture(WebGL2RenderingContext.TEXTURE0+a),o.bindTexture(WebGL2RenderingContext.TEXTURE_2D,n)}if(n!==null&&this.optionsEqual(e))return s(t,e.textureUnit),this.width*this.height;n===null&&(n=this.texture=t.createTexture()),s(t,e.textureUnit),di(t);const r=this.createLookupTable(e);return t.texImage2D(WebGL2RenderingContext.TEXTURE_2D,0,WebGL2RenderingContext.RGBA,this.width,this.height,0,WebGL2RenderingContext.RGBA,WebGL2RenderingContext.UNSIGNED_BYTE,r.outputValues),this.setOptions(e),this.width*this.height}setTextureWidthAndHeightFromSize(e){this.width=e}disposed(){this.gl?.deleteTexture(this.texture),this.texture=null,this.priorOptions=void 0,super.disposed()}}class Hx extends Uf{constructor(e){super(e),this.gl=e,this.texture=null,this.priorOptions=void 0}optionsEqual(e){const t=this.priorOptions;if(t===void 0)return!1;const n=Es.equal(t.lookupTable,e.lookupTable),s=t.textureUnit===e.textureUnit;return n&&s}createLookupTable(e){return this.setTextureWidthAndHeightFromSize(e.lookupTable.lookupTableSize),e.lookupTable}setOptions(e){this.priorOptions={...e,lookupTable:e.lookupTable.copy()}}}class Jx extends Uf{constructor(e){super(e),this.gl=e}optionsEqual(e){const t=this.priorOptions;if(t===void 0)return!1;const n=(0,F.wm)(t.sortedControlPoints.controlPoints,e.sortedControlPoints.controlPoints,(o,a)=>o.inputValue===a.inputValue&&(0,F.r1)(o.outputColor,a.outputColor)),s=t.textureUnit===e.textureUnit,r=t.dataType===e.dataType;return n&&s&&r}setOptions(e){this.priorOptions={...e,sortedControlPoints:e.sortedControlPoints.copy()}}createLookupTable(e){const t=this.ensureTextureSize(e.lookupTableSize);if(t===void 0)return new Es(0);this.setTextureWidthAndHeightFromSize(t);const n=new Es(t),s=e.sortedControlPoints;return n.updateFromControlPoints(s),n}ensureTextureSize(e){const t=this.gl;if(t===null)return;const n=t.getParameter(t.MAX_TEXTURE_SIZE);return Math.min(e,n)}}class jx extends nc{constructor(e){super(e.display,document.createElement("div"),e.visibility),this.parent=e,this.controlPointsPositionArray=new Float32Array,this.controlPointsColorArray=new Float32Array,this.linePositionArray=new Float32Array,this.transferFunction=this.registerDisposer(new Wx(this.parent.dataType,this.parent.trackable,$o)),this.controller=this.registerDisposer(new Qx(this.element,this.parent.dataType,this.transferFunction,()=>this.parent.trackable.value,r=>{this.parent.trackable.value=r})),this.dataValuesBuffer=this.registerDisposer(ci(this.gl,WebGL2RenderingContext.ARRAY_BUFFER,()=>{const r=new Uint8Array(pi*Ut);for(let o=0;o{const r=new fn(this.gl);return In(r),r.addAttribute("vec4","aLineStartEnd"),r.addOutputBuffer("vec4","out_color",0),r.addVarying("float","vColor"),r.setVertexMain(` +vec4 start = vec4(aLineStartEnd[0], aLineStartEnd[1], 0.0, 1.0); +vec4 end = vec4(aLineStartEnd[2], aLineStartEnd[3], 0.0, 1.0); +emitLine(start, end, 1.0); +`),r.setFragmentMain(` +out_color = vec4(0.35, 0.35, 0.35, getLineAlpha()); +`),r.build()})()),this.transferFunctionShader=this.registerDisposer((()=>{const r=new fn(this.gl);return r.addAttribute("vec2","aVertexPosition"),r.addVarying("vec2","vTexCoord"),r.addOutputBuffer("vec4","out_color",0),r.addTextureSampler("sampler2D","uSampler",Vf),r.addUniform("float","uTransferFunctionEnd"),r.setVertexMain(` +gl_Position = vec4(aVertexPosition, 0.0, 1.0); +vTexCoord = (aVertexPosition + 1.0) / 2.0; +`),r.setFragmentMain(` +ivec2 texel = ivec2(floor(vTexCoord.x * uTransferFunctionEnd), 0); +out_color = texelFetch(uSampler, texel, 0); +`),r.build()})()),this.controlPointsShader=this.registerDisposer((()=>{const r=new fn(this.gl);return r.addAttribute("vec2","aVertexPosition"),r.addAttribute("vec3","aVertexColor"),r.addVarying("vec3","vColor"),r.addOutputBuffer("vec4","out_color",0),r.setVertexMain(` +gl_Position = vec4(aVertexPosition, 0.0, 1.0); +gl_PointSize = 14.0; +vColor = aVertexColor; +`),r.setFragmentMain(` +float vColorSum = vColor.r + vColor.g + vColor.b; +vec3 bordercolor = vec3(0.0, 0.0, 0.0); +if (vColorSum < 0.4) { + bordercolor = vec3(1.0, 1.0, 1.0); +} +float dist = distance(gl_PointCoord, vec2(0.5, 0.5)); +float alpha = smoothstep(0.25, 0.4, dist); +vec4 tempColor = vec4(mix(vColor, bordercolor, alpha), 1.0); +alpha = 1.0 - smoothstep(0.4, 0.5, dist); +out_color = tempColor * alpha; +`),r.build()})());const{element:t,gl:n}=this;t.classList.add("neuroglancer-transfer-function-panel"),this.textureVertexBufferArray=df($o),this.texture=this.registerDisposer(new Hx(n));function s(r){return ci(n,WebGL2RenderingContext.ARRAY_BUFFER,()=>r).value}this.textureVertexBuffer=this.registerDisposer(s(this.textureVertexBufferArray)),this.controlPointsVertexBuffer=this.registerDisposer(s(this.controlPointsPositionArray)),this.controlPointsColorBuffer=this.registerDisposer(s(this.controlPointsColorArray)),this.linePositionBuffer=this.registerDisposer(s(this.linePositionArray))}get drawOrder(){return 1}updateTransferFunctionPointsAndLines(){const e=this.parent.trackable.value.window;function t(I){return re(e,I)*2-1}function n(I){return I/255*2-1}function s(I){return I/255}function r(I,L,N){for(let k=0;k=-1&&I<=1}const{transferFunction:a}=this,{controlPoints:l}=a.trackable.value.sortedControlPoints;let c=Math.max(l.length-1,0);const d=xr-1,u=new Float32Array(l.length*d),h=new Float32Array(l.length*2);let p=0,m=null,g=null;const v=l.map(I=>{const L=t(I.inputValue),N=n(I.outputColor[3]);return{input:L,output:N}});if(l.length>0){const{firstPointIndexInWindow:I,lastPointIndexInWindow:L,pointClosestToLeftEdge:N,pointClosestToRightEdge:k}=E();if(I===null){const O=v[l.length-1].input<-1,V=v[0].input>1;O?D():!V&&l.length>1&&x(N,k)}else{const O=v[I];O.input>-1&&(I>0?b(I,O):m=C.ln.fromValues(O.input,-1,O.input,O.output),c+=1);const V=v[L];V.input<1&&(L1){k=V;break}}return{firstPointIndexInWindow:I,lastPointIndexInWindow:L,pointClosestToLeftEdge:N,pointClosestToRightEdge:k}}function D(){const I=l.length-1;c+=1;const L=v[I].output;m=C.ln.fromValues(-1,L,1,L)}}drawIndirect(){const{transferFunctionLineShader:e,gl:t,transferFunctionShader:n,controlPointsShader:s,histogramLineShader:r}=this;this.setGLLogicalViewport(),t.clearColor(0,0,0,0),t.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT),t.enable(WebGL2RenderingContext.BLEND),t.blendFunc(WebGL2RenderingContext.SRC_ALPHA,WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA),t.disable(WebGL2RenderingContext.DEPTH_TEST),t.disable(WebGL2RenderingContext.STENCIL_TEST);{n.bind();const o=n.attribute("aVertexPosition");t.uniform1f(n.uniform("uTransferFunctionEnd"),$o-1),this.textureVertexBuffer.bindToVertexAttrib(o,2,WebGL2RenderingContext.FLOAT);const a=n.textureUnit(Vf);this.texture.updateAndActivate({lookupTable:this.transferFunction.lookupTable,textureUnit:a}),Ao(this.gl,$o,1),t.disableVertexAttribArray(o),t.bindTexture(WebGL2RenderingContext.TEXTURE_2D,null)}if(this.parent.histogramSpecifications.producerVisibility.visible){const{renderViewport:o}=this;r.bind(),vn(r,{width:o.logicalWidth,height:o.logicalHeight},1);const a=r.textureUnit(Bf);t.uniform1f(r.uniform("uBoundsFraction"),le(this.parent.dataType,this.parent.trackable.value.window)),t.activeTexture(WebGL2RenderingContext.TEXTURE0+a),t.bindTexture(WebGL2RenderingContext.TEXTURE_2D,this.parent.texture),di(t);const l=r.attribute("aDataValue");this.dataValuesBuffer.bindToVertexAttribI(l,1,WebGL2RenderingContext.UNSIGNED_BYTE),mn(t,pi,1),t.disableVertexAttribArray(l),t.bindTexture(WebGL2RenderingContext.TEXTURE_2D,null)}if(this.controlPointsPositionArray.length>0){const{renderViewport:o}=this;e.bind();const a=e.attribute("aLineStartEnd");this.linePositionBuffer.bindToVertexAttrib(a,4,WebGL2RenderingContext.FLOAT),vn(e,{width:o.logicalWidth,height:o.logicalHeight},1),mn(t,this.linePositionArray.length/(Ut*_f),1),t.disableVertexAttribArray(a),s.bind();const l=s.attribute("aVertexPosition");this.controlPointsVertexBuffer.bindToVertexAttrib(l,2,WebGL2RenderingContext.FLOAT);const c=s.attribute("aVertexColor");this.controlPointsColorBuffer.bindToVertexAttrib(c,3,WebGL2RenderingContext.FLOAT),t.drawArrays(t.POINTS,0,this.controlPointsPositionArray.length/2),t.disableVertexAttribArray(l),t.disableVertexAttribArray(c)}t.disable(WebGL2RenderingContext.BLEND)}update(){this.transferFunction.updateLookupTable(this.parent.trackable.value.window),this.updateTransferFunctionPointsAndLines()}isReady(){return!0}}function Yx(i,e){function t(r){const o=document.createElement("input");return o.addEventListener("focus",()=>{o.select()}),o.classList.add("neuroglancer-transfer-function-widget-bound"),o.type="text",o.spellcheck=!1,o.autocomplete="off",o.title=`${r===0?"Lower":"Upper"} window for transfer function`,o}const n=document.createElement("div");n.classList.add("neuroglancer-transfer-function-window-bounds");const s=[t(0),t(1)];for(let r=0;r<2;++r){const o=s[r];o.addEventListener("input",()=>{Ec(o)}),o.addEventListener("change",()=>{const a=e.value.window,l={range:a,window:a};try{const c=qt(i,o.value),d=Sr(l,"window",r,c,!0).window;if(d[0]===d[1])throw new Error("Window bounds cannot be equal");e.value={...e.value,window:d}}catch{br(o,a[r])}})}return n.appendChild(s[0]),n.appendChild(s[1]),{container:n,inputs:s}}const kc=Ae.fromObject({"shift?+mousedown0":{action:"add-or-drag-point"},"shift+dblclick0":{action:"remove-point"},"shift?+mousedown2":{action:"change-point-color"},"shift?+wheel":{action:"zoom-via-wheel"}});class Qx extends T.O8{constructor(e,t,n,s,r){super(),this.element=e,this.dataType=t,this.transferFunction=n,this.getModel=s,this.setModel=r,this.currentGrabbedControlPointIndex=-1,e.title=kc.describe(),this.registerDisposer(new tn(e,kc)),Z(e,"add-or-drag-point",o=>{const a=o.detail;this.updateValue(this.addControlPoint(a)),zt(a,l=>{this.updateValue(this.moveControlPoint(l))})}),Z(e,"remove-point",o=>{const a=o.detail,l=this.findControlPointIfNearCursor(a);l!==-1&&(this.transferFunction.removePoint(l),this.updateValue({...this.getModel(),sortedControlPoints:this.transferFunction.trackable.value.sortedControlPoints}))}),Z(e,"change-point-color",o=>{const a=o.detail,l=this.findControlPointIfNearCursor(a);if(l!==-1){const c=this.transferFunction.trackable.value.defaultColor,d=this.convertPanelSpaceColorToAbsoluteValue(c);this.transferFunction.updatePointColor(l,d),this.updateValue({...this.getModel(),sortedControlPoints:this.transferFunction.trackable.value.sortedControlPoints})}}),Z(e,"zoom-via-wheel",o=>{const a=o.detail,l=_i(a),c=this.getTargetFraction(a),{dataType:d}=this,u=this.getModel(),h=de(u.window,d,c*(1-l)),p=de(u.window,d,(1-c)*l+c);h!==p&&this.setModel({...u,window:[h,p]})})}getTargetFraction(e){const t=this.element.getBoundingClientRect();return(e.clientX-t.left)/t.width}updateValue(e){e!==void 0&&this.setModel(e)}convertPanelSpaceInputToAbsoluteValue(e){return de(this.transferFunction.trackable.value.window,this.dataType,e)}convertPanelSpaceColorToAbsoluteValue(e){return e.length===3?C.eR.fromValues(Math.round(e[0]*255),Math.round(e[1]*255),Math.round(e[2]*255)):C.ln.fromValues(Math.round(e[0]*255),Math.round(e[1]*255),Math.round(e[2]*255),Math.round(e[3]*255))}addControlPoint(e){const t=this.transferFunction.trackable.value.defaultColor,n=this.findControlPointIfNearCursor(e);if(n!==-1){this.currentGrabbedControlPointIndex=n;return}const s=this.getControlPointPosition(e);if(s===void 0)return;const{normalizedX:r,normalizedY:o}=s,a=C.ln.fromValues(t[0],t[1],t[2],o);return this.transferFunction.addPoint(new Ln(this.convertPanelSpaceInputToAbsoluteValue(r),this.convertPanelSpaceColorToAbsoluteValue(a))),this.currentGrabbedControlPointIndex=this.findControlPointIfNearCursor(e),{...this.getModel(),sortedControlPoints:this.transferFunction.trackable.value.sortedControlPoints}}moveControlPoint(e){if(this.currentGrabbedControlPointIndex!==-1){const t=this.getControlPointPosition(e);if(t===void 0)return;const{normalizedX:n,normalizedY:s}=t,r=this.transferFunction.trackable.value.sortedControlPoints.controlPoints[this.currentGrabbedControlPointIndex].outputColor;return r[3]=Math.round(s*255),this.currentGrabbedControlPointIndex=this.transferFunction.updatePoint(this.currentGrabbedControlPointIndex,new Ln(this.convertPanelSpaceInputToAbsoluteValue(n),r)),{...this.getModel(),sortedControlPoints:this.transferFunction.trackable.value.sortedControlPoints}}}getControlPointPosition(e){const t=this.element.getBoundingClientRect();let n=(e.clientX-t.left)/t.width,s=(t.bottom-e.clientY)/t.height;if(!(n<0||n>1||s<0||s>1))return n1-Go/3&&(n=1),s1-Go&&(s=1),{normalizedX:n,normalizedY:s}}findControlPointIfNearCursor(e){const{transferFunction:t}=this,{window:n}=t.trackable.value,s=t.sortedControlPoints.controlPoints.length;function r(S){return S<0||S>=s?null:re(n,t.sortedControlPoints.controlPoints[S].inputValue)}function o(S){return S<0||S>=s?null:t.sortedControlPoints.controlPoints[S].outputColor[3]/255}const a=this.getControlPointPosition(e);if(a===void 0)return-1;const l=a.normalizedX,c=a.normalizedY,d=t.findNearestControlPointIndex(l,n);if(d===-1)return-1;const u=r(d);if(Math.abs(l-u)>Rc)return-1;const h=[[d,Math.abs(o(d)-c)]],p=r(d+1);(p!==null?Math.abs(p-l):1/0)<=Rc&&h.push([d+1,Math.abs(o(d+1)-c)]);const g=r(d-1);return(g!==null?Math.abs(g-l):1/0)<=Rc&&h.push([d-1,Math.abs(o(d-1)-c)]),h.sort((S,w)=>S[1]-w[1])[0][0]}}class Kx extends Gt{constructor(e,t,n,s,r,o){super(e),this.display=t,this.dataType=n,this.trackable=s,this.histogramSpecifications=r,this.histogramIndex=o,this.transferFunctionPanel=this.registerDisposer(new jx(this)),this.window=Yx(this.dataType,this.trackable),this.registerDisposer(r.visibility.add(this.visibility));const{element:a}=this;a.classList.add("neuroglancer-transfer-function-widget"),a.appendChild(this.transferFunctionPanel.element),a.appendChild(this.window.container),this.window.container.dispatchEvent(new Event("change"));const l=document.createElement("div");l.classList.add("neuroglancer-transfer-function-color-picker");const c=this.registerDisposer(new hi((0,_.Uq)(d=>d.defaultColor,[s]),()=>C.eR.fromValues(1,1,1)));c.element.title="Transfer Function Color Picker",c.element.id="neuroglancer-tf-color-widget",c.element.addEventListener("change",()=>{s.value={...this.trackable.value,defaultColor:c.model.value}}),c.element.addEventListener("input",()=>{s.value={...this.trackable.value,defaultColor:c.model.value}}),l.appendChild(c.element),a.appendChild(l),this.updateControlPointsAndDraw(),this.registerDisposer(this.trackable.changed.add(()=>{this.updateControlPointsAndDraw()}))}get texture(){return this.histogramSpecifications.getFramebuffers(this.display.gl)[this.histogramIndex].colorBuffers[0].texture}updateView(){for(let e=0;e<2;++e)br(this.window.inputs[e],this.trackable.value.window[e]);this.transferFunctionPanel.scheduleRedraw()}updateControlPointsAndDraw(){this.transferFunctionPanel.update(),this.updateView()}}function qx(i,e,t,n){i.addUniform("highp float",`uTransferFunctionEnd_${e}`),i.addTextureSampler("sampler2D",`uTransferFunctionSampler_${e}`,`TransferFunction.${e}`);const s=Ss(i,e,t,!0),r=yt(t);let o=` +vec4 ${e}_(float inputValue) { + int index = clamp(int(round(inputValue * uTransferFunctionEnd_${e})), 0, int(uTransferFunctionEnd_${e})); + return texelFetch(uTransferFunctionSampler_${e}, ivec2(index, 0), 0); +} +vec4 ${e}(${r} inputValue) { + float v = computeInvlerp(inputValue, uLerpParams_${e}); + defaultMaxProjectionIntensity = v; + return v < 0.0 ? vec4(0.0, 0.0, 0.0, 0.0) : ${e}_(clamp(v, 0.0, 1.0)); +} +vec4 ${e}() { + return ${e}(getDataValue(${n.join(",")})); +} +`;if(t!==R.UINT64&&t!==R.FLOAT32){const a=ae[t]?"int":"uint";o+=` +vec4 ${e}(${a} inputValue) { + return ${e}(${r}(inputValue)); +} +`}return[s[0],s[1],s[2],o]}function Xx(i,e,t,n,s=Ff[t]){const{gl:r}=i;i.transferFunctionTextures.get(`TransferFunction.${e}`)===void 0&&i.transferFunctionTextures.set(`TransferFunction.${e}`,new Jx(r));const a=i.bindAndUpdateTransferFunctionTexture(`TransferFunction.${e}`,n,t,s);if(a===void 0)throw new Error("Failed to create transfer function texture");r.uniform1f(i.uniform(`uTransferFunctionEnd_${e}`),a-1);const l=n.range;Ni(i,e,t,l)}function Zx(i,e){i.bindInputEventMap(kc)}function eE(i){return{makeControl:(e,t,n)=>{const{watchableValue:s,channelCoordinateSpaceCombiner:r,defaultChannel:o,histogramSpecifications:a,histogramIndex:l,dataType:c}=i(e);if(r!==void 0&&o.length!==0){const u=t.registerDisposer(new ui(r.combined)),h=t.registerDisposer(new xs(u,r,{copyButton:!1}));t.registerDisposer(u.changed.add(()=>{const m=u.value,g=Array.from(m,y=>Math.floor(y)),v=s.value;(0,F.r1)(v.channel,g)||(s.value={...s.value,channel:g})}));const p=()=>{const m=u.value,g=s.value;(0,F.r1)(g.channel,m)||(m.set(g.channel),u.changed.dispatch())};p(),t.registerDisposer(s.changed.add(p)),n.labelContainer.appendChild(h.element)}const d=t.registerDisposer(new Kx(n.visibility,n.display,c,s,a,l));return{control:d,controlElement:d.element}},activateTool:(e,t)=>{Zx(e,t)}}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function tE(i){const e=/\/\/.*?$|\/\*(?:.|\n)*?\*\/|'(?:\\.|[^\\'])*'|"(?:\\.|[^\\"])*"/gm;return i.replace(e,t=>t.startsWith("/")?t.replace(/[^\s]/g," "):t)}function nE(i){const e=/^(?:-?(?:0|[1-9]\d*)(?:\.\d+)?(?:[eE][+-]?\d+)?|"(?:\\.|[^\\"])*"|true|false|:|\s+|,|\[|\]|\{|\})/;let t=0;const n=i;e:for(;i.length;){const s=i.match(e);if(s===null)break;const r=s[0];switch(r.charAt(0)){case"[":case"{":++t;break;case"]":case"}":if(--t<0)return-1;break;case",":if(t===0)break e;break;default:if(t===0){i=i.substring(r.length);break e}break}i=i.substring(r.length)}return t!==0?-1:n.length-i.length}function iE(i){const e=[],t=new Map;if(i===void 0)return{errors:e,parameters:t};const n=/^([_a-z][_a-zA-Z0-9]*)[ \t]*=/;for(;i=i.trim(),i.length!==0;){const s=i.match(n);if(s===null){e.push("Invalid #uicontrol parameter syntax, expected: =, ...");break}const r=s[1];i=i.substring(s[0].length);const o=nE(i);if(o<=0){e.push("Invalid #uicontrol parameter syntax, expected: =, ...");break}let a;try{a=JSON.parse(i.substring(0,o))}catch{e.push(`Invalid #uicontrol parameter value for ${r}: ${a}`);break}t.has(r)?e.push(`Duplicate #uicontrol parameter: ${r}`):t.set(r,a),i=i.substring(o),i=i.trim(),i.length>0&&!i.startsWith(",")&&e.push("Invalid #uicontrol parameter syntax, expected: =, ..."),i=i.substring(1)}return{parameters:t,errors:e}}function sE(i,e){let t,n,s,r;const o=[];i!=="float"&&i!=="uint"&&i!=="int"&&o.push("type must be float, int, or uint");for(const[a,l]of e){const c=()=>{if(typeof l!="number"){o.push(`Expected ${a} argument to be a number`);return}return(i==="int"||i==="uint")&&(Number.isInteger(l)||o.push(`Expected ${a} argument to be an integer`),i==="uint"&&l<0&&o.push(`Expected ${a} argument to be an unsigned integer`)),l};a==="min"?t=c():a==="max"?n=c():a==="default"?r=c():a==="step"?s=c():o.push(`Invalid parameter: ${a}`)}return t===void 0&&o.push("min must be specified"),n===void 0&&o.push("max must be specified"),t!==void 0&&n!==void 0&&(t>n&&o.push("min must be less than max"),s===void 0&&(i==="float"?s=(n-t)/100:s=1),r!==void 0?(rn)&&o.push("default must be within valid range"):i==="float"?r=(t+n)/2:r=t),o.length>0?{errors:o}:{control:{type:"slider",valueType:i,min:t,max:n,step:s,default:r},errors:void 0}}function rE(i,e){let t=!1;const n=[];i!=="bool"&&n.push("type must be bool");for(const[s,r]of e)if(s==="default"){if(typeof r!="boolean"){n.push(`Expected ${s} argument to be a boolean`);continue}t=r}else n.push(`Invalid parameter: ${s}`);return n.length>0?{errors:n}:{control:{type:"checkbox",valueType:i,default:t},errors:void 0}}function oE(i,e){let t="white";const n=[];i!=="vec3"&&n.push("type must be vec3");for(const[s,r]of e)s==="default"?typeof r!="string"?n.push("Expected default argument to be a string"):t=r:n.push(`Invalid parameter: ${s}`);return n.length>0?{errors:n}:{control:{type:"color",valueType:i,defaultString:t,default:me(t)},errors:void 0}}function Wo(i,e){typeof i=="number"&&(i=[i]);const t=new Array(e);return(0,f.Xu)(t,i,n=>{if(!Number.isInteger(n)||n<0)throw new Error(`Expected non-negative integer, but received: ${JSON.stringify(n)}`);return n}),t}function aE(i,e,t){const{imageData:n,properties:s}=t;if(n!==void 0)return lE(i,e,n);if(s!==void 0)return cE(i,e,s);const r=[];return r.push("invlerp control not supported"),{errors:r}}function lE(i,e,t){const n=[];i!=="invlerp"&&n.push("type must be invlerp");let s=new Array(t.channelRank).fill(0);const{dataType:r}=t;let o=!0,a=he[r],l;for(const[c,d]of e)try{switch(c){case"range":{a=Lt(d,r);break}case"window":{l=et(Lt(d,r));break}case"clamp":{typeof d!="boolean"?n.push(`Invalid clamp value: ${JSON.stringify(d)}`):o=d;break}case"channel":{s=Wo(d,s.length);break}default:n.push(`Invalid parameter: ${c}`);break}}catch(u){n.push(`Invalid ${c} value: ${u.message}`)}return n.length>0?{errors:n}:{control:{type:"imageInvlerp",dataType:r,clamp:o,default:{range:a,window:l??st(a),channel:s}},errors:void 0}}function cE(i,e,t){const n=[];i!=="invlerp"&&n.push("type must be invlerp");let s=!0,r,o,a;for(const[c,d]of e)try{switch(c){case"range":{r=Ii(d);break}case"window":{o=Ii(d);break}case"clamp":{typeof d!="boolean"?n.push(`Invalid clamp value: ${JSON.stringify(d)}`):s=d;break}case"property":{const u=(0,f.zr)(d);if(!t.has(u))throw new Error(`Property not defined: ${JSON.stringify(a)}`);a=u;break}default:n.push(`Invalid parameter: ${c}`);break}}catch(u){n.push(`Invalid ${c} value: ${u.message}`)}if(n.length>0)return{errors:n};if(a===void 0)for(const c of t.keys()){a=c;break}const l=t.get(a);return r!==void 0&&(r=Ce(r,l)),o!==void 0&&(o=Ce(o,l)),{control:{type:"propertyInvlerp",clamp:s,properties:t,default:{range:r,window:o,property:a,dataType:l}},errors:void 0}}function dE(i,e,t){const n=t.imageData,s=n?.dataType,r=n?.channelRank,o=[];let a=new Array(r).fill(0),l=C.eR.fromValues(1,1,1),c,d=new zo([],s!==void 0?s:R.FLOAT32),u=!1;i!=="transferFunction"&&o.push("type must be transferFunction"),s===void 0&&o.push("image data must be provided to use a transfer function");for(const[h,p]of e)try{switch(h){case"channel":{a=Wo(p,a.length);break}case"defaultColor":{l=me(p);break}case"window":{s!==void 0&&(c=et(Lt(p,s)));break}case"controlPoints":{u=!0,s!==void 0&&(d=zf(p,s));break}default:o.push(`Invalid parameter: ${h}`);break}}catch(m){o.push(`Invalid ${h} value: ${m.message}`)}if(c===void 0&&(c=d.range),d.length===0&&!u&&s!==void 0){const h=de(c,s,.4),p=de(c,s,.7);d.addPoint(new Ln(h,C.yb)),d.addPoint(new Ln(p,C.ln.fromValues(255,255,255,255)))}return o.length>0?{errors:o}:{control:{type:"transferFunction",dataType:s,default:{sortedControlPoints:d,channel:a,defaultColor:l,window:c}},errors:void 0}}const uE=new Map([["slider",sE],["color",oE],["invlerp",aE],["checkbox",rE],["transferFunction",dE]]);function Er(i,e={}){i=tE(i);const t=/^[ \t]*#[ \t]*uicontrol[ \t]+(.*)$/gm,n=/^([_a-zA-Z][_a-zA-Z0-9]*)[ \t]+([a-z][a-zA-Z0-9_]*)(?:[ \t]+([a-z]+))?[ \t]*(?:\([ \t]*(.*)\)[ \t]*)?/,s=[],r=new Map,o=i.replace(t,(a,l,c)=>{const d=l.match(n),u=()=>Math.max(0,i.substring(0,c).split(` +`).length-1);if(d===null)return s.push({line:u(),message:"Invalid #uicontrol syntax, expected: #uicontrol (=, ...)"}),"";const h=d[1],p=d[2],m=d[3]??h,g=d[4],{parameters:v,errors:y}=iE(g);for(const b of y)s.push({line:u(),message:b});if(r.has(p)&&s.push({line:u(),message:`Duplicate definition for control ${p}`}),y.length>0)return"";const S=uE.get(m);if(S===void 0)return s.push({line:u(),message:`Invalid control type ${m}`}),"";const w=S(h,v,e);if(w.errors!==void 0){for(const b of w.errors)s.push({line:u(),message:b});return""}return r.set(p,w.control),""});return{source:i,code:o,errors:s,controls:r}}function $f(i){return`u_shaderControl_${i}`}function Ts(i,e){const{builderValues:t}=i;for(const[n,s]of i.parseResult.controls){const r=$f(n),o=t[n];switch(s.type){case"imageInvlerp":{const a=[Ss(e,r,s.dataType,s.clamp),` +float ${r}() { + return ${r}(getDataValue(${o.channel.join(",")})); +} +`];e.addFragmentCode(a),e.addFragmentCode(`#define ${n} ${r} +`);break}case"propertyInvlerp":{const a=o.property,l=s.properties.get(a),c=[Ss(e,r,l,s.clamp),` +float ${r}() { + return ${r}(prop_${a}()); +} +`];e.addVertexCode(c),e.addVertexCode(`#define ${n} ${r} +`);break}case"checkbox":{const a=`#define ${n} ${o.value} +`;e.addFragmentCode(a),e.addVertexCode(a);break}case"transferFunction":{e.addFragmentCode(`#define ${n} ${r} +`),e.addFragmentCode(qx(e,r,s.dataType,o.channel));break}default:{e.addUniform(`highp ${s.valueType}`,r),e.addVertexCode(`#define ${n} ${r} +`),e.addFragmentCode(`#define ${n} ${r} +`);break}}}}function hE(i){const e={};for(const[t,n]of i)e[t]=n;return e}function pE(i,e){return e instanceof Map?Array.from(e.entries()):e}function Gf(i){if(i!==void 0)return JSON.stringify(hE(i),pE)}class fE{constructor(){this.changed=new j.IY,this.controls=void 0}get value(){return this.controls}set value(e){Gf(e)!==Gf(this.controls)&&(this.controls=e,this.changed.dispatch())}}function gE(i,e,t){return i===void 0?t:((0,f.Rf)(i),{range:(0,f.MM)(i,"range",n=>Lt(n,e),t.range),window:(0,f.MM)(i,"window",n=>et(Lt(n,e)),t.window),channel:(0,f.MM)(i,"channel",n=>Wo(n,t.channel.length),t.channel)})}class mE extends _.DN{constructor(e,t){super(t,n=>gE(n,e,t)),this.dataType=e,this.defaultValue=t}toJSON(){const{value:{range:e,window:t,channel:n},dataType:s,defaultValue:r}=this,o=A(e,s,r.range),a=A(t,s,r.window),l=(0,F.r1)(r.channel,n)?void 0:n;if(!(o===void 0&&a===void 0&&l===void 0))return{range:o,window:a,channel:l}}}function vE(i,e,t){if(i===void 0)return t;(0,f.Rf)(i);const n=(0,f.MM)(i,"property",r=>{if(r=(0,f.zr)(r),!e.has(r))throw new Error(`Invalid value: ${JSON.stringify(r)}`);return r},t.property),s=e.get(n);return{property:n,dataType:s,range:(0,f.MM)(i,"range",r=>Lt(r,s),t.range),window:(0,f.MM)(i,"window",r=>et(Lt(r,s)),t.window)}}class yE extends _.DN{constructor(e,t){super(t,n=>vE(n,e,t)),this.properties=e,this.defaultValue=t}toJSON(){const{value:{range:e,window:t,property:n,dataType:s},defaultValue:r}=this,o=he[s],a=A(e??o,s,r.range??o),l=A(t??o,s,r.window??o),c=n===r.property?void 0:n;if(!(a===void 0&&l===void 0&&c===void 0))return{range:a,window:l,property:c}}}function zf(i,e){const t=(0,f.$v)(i,n=>{const s=e===R.UINT64&&typeof n[0]=="string"||typeof n[0]=="number";if(n.length!==3||!s||typeof n[1]!="string"||typeof n[2]!="number")throw new Error(`Expected array of length 3 (x, "#RRGGBB", A), but received: ${JSON.stringify(n)}`);const r=qt(e,n[0]);if(n[1].length!==7||n[1][0]!=="#")throw new Error(`Expected #RRGGBB, but received: ${JSON.stringify(n[1])}`);if(n[2]<0||n[2]>1)throw new Error(`Expected opacity in range [0, 1], but received: ${JSON.stringify(n[2])}`);const o=me(n[1]);function a(l){return Math.min(255,Math.max(Math.round(l*255),0))}return new Ln(r,C.ln.fromValues(a(o[0]),a(o[1]),a(o[2]),a(n[2])))});return new zo(t,e)}function SE(i,e,t){if(i===void 0)return t;(0,f.Rf)(i);const n=(0,f.MM)(i,"controlPoints",r=>zf(r,e),t.sortedControlPoints),s=(0,f.MM)(i,"window",r=>Lt(r,e),t.window);return{sortedControlPoints:n,channel:(0,f.MM)(i,"channel",r=>Wo(r,t.channel.length),t.channel),defaultColor:(0,f.MM)(i,"defaultColor",r=>me(r),t.defaultColor),window:s}}function bE(i){return{...i,sortedControlPoints:i.sortedControlPoints.copy()}}class CE extends _.DN{constructor(e,t){const n=bE(t);super(n,s=>SE(s,e,n)),this.dataType=e,this.defaultValue=t}controlPointsToJson(e,t){function n(s){return t===R.UINT64?s.toJSON():s}return e.map(s=>[n(s.inputValue),Ge(C.eR.fromValues(s.outputColor[0]/255,s.outputColor[1]/255,s.outputColor[2]/255)),s.outputColor[3]/255])}toJSON(){const{value:{channel:e,sortedControlPoints:t,defaultColor:n,window:s},dataType:r,defaultValue:o}=this,a=A(s,r,o.window),l=(0,F.r1)(o.channel,e)?void 0:e,c=(0,F.r1)(o.defaultColor,n)?void 0:Ge(n),d=(0,F.wm)(o.sortedControlPoints.controlPoints,t.controlPoints,(u,h)=>(0,F.r1)(u.outputColor,h.outputColor)&&u.inputValue===h.inputValue)?void 0:this.controlPointsToJson(t.controlPoints,r);if(!(l===void 0&&c===void 0&&d===void 0&&a===void 0))return{channel:l,defaultColor:c,controlPoints:d,window:a}}}function Wf(i){switch(i.type){case"slider":return{trackable:new _.DN(i.default,e=>{let t;if(i.valueType==="float"?t=(0,f.zo)(e):t=(0,f.bX)(e),ti.max)throw new Error(`${JSON.stringify(e)} is outside valid range [${i.min}, ${i.max}]`);return t}),getBuilderValue:()=>null};case"color":return{trackable:new q(i.default),getBuilderValue:()=>null};case"imageInvlerp":return{trackable:new mE(i.dataType,i.default),getBuilderValue:e=>({channel:e.channel,dataType:i.dataType})};case"propertyInvlerp":return{trackable:new yE(i.properties,i.default),getBuilderValue:e=>({property:e.property,dataType:e.dataType})};case"checkbox":return{trackable:new nt(i.default),getBuilderValue:e=>({value:e})};case"transferFunction":return{trackable:new CE(i.dataType,i.default),getBuilderValue:e=>({channel:e.channel,dataType:i.dataType})}}}function Hf(i,e){return JSON.stringify(i)+"\0"+e.source}function Ho(i){const e={},t=[];for(const[n,s]of i.controls){const{trackable:r,getBuilderValue:o}=Wf(s),a=o(r.value);e[n]=a,s.type==="propertyInvlerp"&&t.push(a.property)}return{builderValues:e,parseResult:i,key:Hf(e,i),referencedProperties:t}}class Jo extends T.O8{constructor(e,t=(0,_.XZ)({}),n){super(),this.fragmentMain=e,this.dataContext=t,this.channelCoordinateSpaceCombiner=n,this.changed=new j.IY,this.controls=new fE,this.fragmentMainGeneration=-1,this.dataContextGeneration=-1,this.parseErrors_=[],this.processedFragmentMain_="",this.controlsGeneration=-1,this.parseResultChanged=new j.IY,this.state_=new Map,this.unparsedJson=void 0,this.registerDisposer(e.changed.add(()=>this.handleFragmentMainChanged())),this.registerDisposer(this.controls.changed.add(()=>this.handleControlsChanged())),this.registerDisposer(this.dataContext.changed.add(()=>this.handleFragmentMainChanged())),this.handleFragmentMainChanged();const s=this;this.parseErrors={changed:this.parseResultChanged,get value(){return s.handleFragmentMainChanged(),s.parseErrors_}},this.processedFragmentMain={changed:this.parseResultChanged,get value(){return s.handleFragmentMainChanged(),s.processedFragmentMain_}},this.parseResult={changed:this.parseResultChanged,get value(){return s.parseResult_}},this.builderState=(0,_.Uq)((l,c)=>{const d={},u=[];for(const[h,{control:p,trackable:m,getBuilderValue:g}]of c){const v=g(m.value);d[h]=v,p.type==="propertyInvlerp"&&u.push(v.property)}return{key:Hf(d,l),parseResult:l,builderValues:d,referencedProperties:u}},[this.parseResult,this],(l,c)=>l.key===c.key);const r=(0,_.Uq)(l=>{const c=[];for(const{control:d,trackable:u}of l.values())d.type!=="imageInvlerp"&&d.type!=="transferFunction"||c.push({channel:u.value.channel});return c},[this],(l,c)=>(0,F.wm)(l,c,(d,u)=>(0,F.r1)(d.channel,u.channel))),o=(0,_.Uq)(l=>{const c=[];for(const{control:d,trackable:u}of l.values())d.type==="propertyInvlerp"&&c.push(u.value.property);return c},[this],F.r1),a=(0,_.ol)(l=>{const c=[];for(const{control:d,trackable:u}of l.values())if(d.type==="imageInvlerp"||d.type==="transferFunction")c.push(u.value.window);else if(d.type==="propertyInvlerp"){const{dataType:h,range:p,window:m}=u.value;c.push(m??p??he[h])}return c},this);this.histogramSpecifications=this.registerDisposer(new Np(r,o,a))}handleFragmentMainChanged(){const e=this.fragmentMain.changed.count,t=this.dataContext.changed.count;if(e===this.fragmentMainGeneration&&t===this.dataContextGeneration)return;this.fragmentMainGeneration=e,this.dataContextGeneration=t;const n=this.dataContext.value;if(n===null)this.parseResult_={source:"",code:"",controls:new Map,errors:[{line:0,message:"Loading"}]},this.parseErrors_=[],this.processedFragmentMain_="",this.controls.value=void 0;else{const s=this.parseResult_=Er(this.fragmentMain.value,n);this.parseErrors_=s.errors,this.processedFragmentMain_=s.code,s.errors.length===0&&(this.controls.value=s.controls)}this.parseResultChanged.dispatch()}handleControlsChanged(){const e=this.controls.changed.count;if(e===this.controlsGeneration)return;this.controlsGeneration=e;const t=this.controls.value;if(t===void 0)return;let n=!1;const{state_:s,unparsedJson:r}=this;for(const[o,a]of s)t.get(o)===void 0&&(a.trackable.changed.remove(this.changed.dispatch),s.delete(o),n=!0);for(const[o,a]of t){let l=s.get(o);if(l!==void 0&&JSON.stringify(l.control)!==JSON.stringify(a)&&(l.trackable.changed.remove(this.changed.dispatch),l=void 0),l===void 0){const{trackable:c,getBuilderValue:d}=Wf(a);l={control:a,trackable:c,getBuilderValue:d},l.trackable.changed.add(this.changed.dispatch),s.set(o,l),n=!0}if(r!==void 0&&Object.prototype.hasOwnProperty.call(r,o)){n=!0;try{l.trackable.restoreState(r[o])}catch{}}}r!==void 0&&(n=!0),this.unparsedJson=void 0,n&&this.changed.dispatch()}get state(){return this.controls.changed.count!==this.controlsGeneration&&this.handleControlsChanged(),this.state_}get value(){return this.state}restoreState(e){if(e===void 0)return;const{state:t}=this;if((0,f.Rf)(e),this.controls.value===void 0){this.unparsedJson=e,this.changed.dispatch();return}for(const[s,r]of t){const{trackable:o}=r;if(o.reset(),Object.prototype.hasOwnProperty.call(e,s))try{o.restoreState(e[s])}catch{}}this.unparsedJson=void 0}reset(){for(const e of this.state.values())e.trackable.reset();this.unparsedJson!==void 0&&(this.unparsedJson=void 0,this.changed.dispatch())}toJSON(){const{state:e}=this,{unparsedJson:t}=this;if(t!==void 0)return t;const n={};let s=!0;for(const[r,o]of e){const a=o.trackable.toJSON();a!==void 0&&(n[r]=a,s=!1)}if(!s)return n}}function Jf(i,e,t,n,s){const r=$f(t),o=e.uniform(r);switch(n.type){case"slider":switch(n.valueType){case"int":case"uint":i.uniform1i(o,s);break;case"float":i.uniform1f(o,s)}break;case"color":i.uniform3fv(o,s);break;case"imageInvlerp":Ni(e,r,n.dataType,s.range);break;case"propertyInvlerp":{const{dataType:a}=s;Ni(e,r,a,s.range??he[a]);break}case"checkbox":break;case"transferFunction":Xx(e,r,n.dataType,s.sortedControlPoints)}}function vi(i,e,t,n){const{state:s}=t;if(t.controls.value===n)for(const[r,o]of s)Jf(i,e,r,o.control,o.trackable.value);else for(const[r,o]of n){const a=s.get(r),l=a!==void 0&&JSON.stringify(a.control)===JSON.stringify(o)?a.trackable.value:o.default;Jf(i,e,r,o,l)}}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class wE extends _.B0{}class xE extends rc{constructor(){super((e,{showMatches:t,segmentationState:n})=>{e.registerDisposer(t.changed.add(this.changed.dispatch)),e.registerDisposer(n.changed.add(this.changed.dispatch)),e.registerDisposer((0,_.no)((s,r)=>{if(r==null)return;const{segmentationGroupState:o}=r;s.registerDisposer(o.changed.add(this.changed.dispatch)),s.registerDisposer((0,_.no)((a,l)=>{const{visibleSegments:c}=l;let d=c.size===0;a.registerDisposer(c.changed.add(()=>{const u=c.size===0;u!==d&&(d=u,this.changed.dispatch())}))},o))},n))})}get(e){let t=super.get(e);return t===void 0&&(t={segmentationState:new _.B0(void 0),showMatches:new nt(!1)},super.set(e,t)),t}}const jf=` +void main() { + setColor(defaultColor()); +} +`;class Yf extends T.O8{constructor(){super(...arguments),this.annotationProperties=new _.B0(void 0),this.shader=Co(jf),this.shaderControls=new Jo(this.shader,(0,_.ol)(e=>{const t=new Map;if(e===void 0)return null;for(const n of e){const s=kl[n.type];s!==void 0&&t.set(n.identifier,s)}return{properties:t}},this.annotationProperties)),this.fallbackShaderControls=new _.B0(Ho(Er(jf))),this.shaderError=dr(),this.color=new q(C.eR.fromValues(1,1,0)),this.relationshipStates=this.registerDisposer(new xE),this.ignoreNullSegmentFilter=new nt(!0),this.swapVisibleSegmentsOnMove=new nt(!0),this.disablePicking=new _.B0(!1),this.displayUnfiltered=(0,_.ol)((e,t)=>{for(const n of e.values())if(n.showMatches.value){if(!t)return!1;const s=n.segmentationState.value;if(s!=null&&s.segmentationGroupState.value.visibleSegments.size>0)return!1}return!0},this.relationshipStates,this.ignoreNullSegmentFilter),this.hoverState=new wE(void 0)}}class jo extends T.O8{constructor(e){super();const{transform:t,localPosition:n,source:s,role:r=li.ANNOTATION}=e;this.transform=t,this.localPosition=n,this.source=this.registerDisposer(s),this.role=r,this.displayState=e.displayState,this.chunkTransform=this.registerDisposer((0,_.ol)(o=>bo(()=>po(sc(o))),this.transform)),this.dataSource=e.dataSource,this.subsourceId=e.subsourceId,this.subsourceIndex=e.subsourceIndex,this.subsubsourceId=e.subsubsourceId}get sourceIndex(){const{dataSource:e}=this;return e.layer.dataSources.indexOf(e)}}var Qf=G(9459);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Yo=!1,EE=!1,TE=C.pB.create();function DE(i,e){let t=0,n=Math.abs(i.detTransform);const{transform:s,size:r}=i;for(let o=0;o<3;++o){let a=0;for(let c=0;c<3;++c)a+=e[c*4+2]*s[4*o+c];const l=r[o];t+=Math.abs(a)*l,n*=l}return n/t}function Kf(i,e,t){const{curPositionInChunks:n,fixedPositionWithinChunk:s}=i,{nonDisplayLowerClipBound:r,nonDisplayUpperClipBound:o}=i,{rank:a,chunkDataSize:l}=i.source.spec;if(!gs(n,e,t,i.layerRank,i.fixedLayerToChunkTransform))return!1;for(let c=0;c=o[c])return Yo&&console.log("excluding source",i,`because of chunkDim=${c}, sum=${d}`,r,o,i.fixedLayerToChunkTransform),!1;const u=l[c],h=n[c]=Math.floor(d/u);s[c]=d-h*u}return!0}function IE(i,e){const t=e.length;let n=0;if(Yo&&console.log(e),t>1){let s=0;for(let r=0;rs&&(s=l,n=r)}}return n}const Ds=new Qf.i(C.eR.create(),C.pB.create(),0);class LE extends op{constructor(){super(...arguments),this.viewportNormalInGlobalCoordinates=C.eR.create(),this.viewportNormalInCanonicalCoordinates=C.eR.create(),this.centerDataPosition=C.eR.create(),this.pixelSize=0}}function RE(i,e){if(i.displayDimensionRenderInfo!==e.displayDimensionRenderInfo||i.pixelSize!==e.pixelSize)return!0;const{viewMatrix:t}=i,{viewMatrix:n}=e;for(let s=0;s<12;++s)if(t[s]!==n[s])return!0;return!1}class kE extends hn{constructor(e){super(),this.projectionParameters=e,this.visibleLayers=new Map,this.visibleSourcesStale=!0,this.registerDisposer(e.changed.add((t,n)=>{RE(t,n)&&this.invalidateVisibleSources(),this.invalidateVisibleChunks()}))}invalidateVisibleSources(){this.visibleSourcesStale=!0}invalidateVisibleChunks(){}updateVisibleSources(){if(!this.visibleSourcesStale)return;this.visibleSourcesStale=!1;const e=this.projectionParameters.value.displayDimensionRenderInfo,{visibleLayers:t}=this;for(const[n,s]of t){const{allSources:r,visibleSources:o}=s;if(o.length=0,r.length===0||!qw(s,e))continue;const a=IE(this.projectionParameters.value.viewMatrix,r.map(c=>c[0])),l=r[a];for(const c of n.filterVisibleSources(this,l))o.push(c);o.reverse(),Yo&&console.log("visible sources chosen",o)}}}const PE=18;function Qo(i){let{rank:e,upperVoxelBound:t,maxVoxelsPerChunkLog2:n=PE,chunkToViewTransform:s,displayRank:r,minBlockSize:o,maxBlockSize:a}=i;const{lowerVoxelBound:l=new Uint32Array(e)}=i,c=new Float32Array(e);for(let p=0;p=u[g])continue;const v=d[g]*c[g];v3)throw new Error("Unsupported view transform");if(t<3)return[Qo(i)];for(let r=0;r<3;++r){const o=(r+2)%3,a=new Float32Array(n);for(let l=0;l(i[i.ISOTROPIC=0]="ISOTROPIC",i[i.FLAT=1]="FLAT",i))(qf||{});function zV(i,e,t){return t===void 0?e:matrix.multiply(new Float32Array((i+1)*(i+1)),i+1,e,i+1,t,i+1,i+1,i+1,i+1)}function ME(i){if(i.chunkDataSizes!==void 0)return i.chunkDataSizes;const{chunkLayoutPreference:e=0}=i;switch(e){case 0:return[Qo(i)];case 1:return AE(i)}}function Ko(i){const{rank:e,chunkDataSize:t,upperVoxelBound:n}=i,{lowerVoxelBound:s=new Float32Array(e)}=i,r=new Float32Array(e),o=new Float32Array(e);for(let a=0;a{const u=n*r;for(let h=0;h<3;++h){const p=d[h];if(p>u&&p>1.01*s[h])return!0}return!1},a=(d,u)=>{const h=n*r;for(let p=0;p<3;++p){const m=d[p],g=u[p];if(Math.abs(h-m)h&&(h=S,u=y)}if(p===0)return;if(p===1){l[c[0]]=s[0],l[c[1]]=s[1],l[c[2]]=s[2],t(s,i);return}const m=s[u],g=r[u],v=Math.floor(.5*(m+g));r[u]=v,d(),r[u]=g,s[u]=v,d(),s[u]=m}d()}function tg(i,e,t,n){if(!Kf(t,i.globalPosition,e))return;const{size:s}=t.chunkLayout,r=C.pB.multiply(Xf,i.viewProjectionMat,t.chunkLayout.transform);for(let c=0;c<3;++c){const d=s[c];for(let u=0;u<4;++u)r[4*c+u]*=d}const o=Zf;(0,C._S)(o,r);const a=Pc,l=Ac;a.fill(Number.NEGATIVE_INFINITY),l.fill(Number.POSITIVE_INFINITY),eg(o,t,n,C.T_)}function UE(i,e,t,n,s){if(!Kf(t,i.globalPosition,e))return;const{size:r}=n,o=C.pB.multiply(Xf,i.viewProjectionMat,n.transform);for(let h=0;h<3;++h){const p=r[h];for(let m=0;m<4;++m)o[4*h+m]*=p}const a=TE;C.pB.invert(a,o);const l=Pc,c=Ac,d=.001;for(let h=0;h<3;++h){const p=a[12+h]+d/r[h],m=Math.abs(a[h]),g=Math.abs(a[4+h]);l[h]=Math.floor(p-m-g),c[h]=Math.floor(p+m+g+1)}const u=Zf;for(let h=0;h<3;++h){const p=o[4*h],m=o[4*h+1],g=o[4*h+2];u[h]=p,u[4+h]=-p,u[8+h]=+m,u[12+h]=-m,u[16+h]=+g,u[20+h]=-g}{const p=o[12],m=o[4*3+1],g=o[4*3+2];u[3]=1+p,u[7]=1-p,u[11]=1+m,u[15]=1-m,u[19]=g,u[23]=-g}EE&&(console.log("clippingPlanes",u),console.log("modelViewProjection",o.join(",")),console.log(`lower=${l.join(",")}, upper=${c.join(",")}`)),eg(u,t,s,C.qp)}function Mc(i,e){const{finiteRank:t}=e;if(t===3)return e;Ds.finiteRank=t,C.eR.copy(Ds.size,e.size);const n=C.pB.copy(Ds.transform,e.transform),s=C.pB.copy(Ds.invTransform,e.invTransform);Ds.detTransform=e.detTransform;const{invViewMatrix:r,width:o,height:a}=i,l=(0,C.sJ)(i.projectionMat);for(let c=t;c<3;++c){const d=r[12+c];let u=d,h=d;const p=Math.abs(r[c]*o);u-=p,h+=p;const m=Math.abs(r[c+4]*a);u-=m,h+=m;const g=Math.abs(r[c+8]*l);u-=g,h+=g;const v=Math.max(1,h-u);n[12+c]=u,n[5*c]=v}return C.pB.invert(s,n),Ds}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const $E="annotation.MetadataChunkSource",GE="annotation.GeometryChunkSource",zE="annotation.SubsetGeometryChunkSource",WE="annotation.reference.add",HE="annotation.reference.delete",JE="annotation.commit",jE="annotation.commit",YE="annotation/SpatiallyIndexedRenderLayer",QE="annotation/PerspectiveRenderLayer:updateSources",KE="annotation/RenderLayer",qE="annotation/RenderLayer.updateSegmentation",XE=C.w0.create();function ng(i,e,t,n,s,r){const{displayDimensionRenderInfo:o,viewMatrix:a,projectionMat:l,width:c,height:d}=i,{voxelPhysicalScales:u}=o,h=Math.abs(C.w0.determinant((0,C._A)(XE,a))),p=(0,C.xK)(u),m=(0,C.I1)(l)/h*p;if(n.length===0)return;const g=n[0];let v=Math.abs(g.chunkLayout.detTransform)*p;const{lowerClipDisplayBound:y,upperClipDisplayBound:S}=g;for(let I=0;I<3;++I)v*=S[I]-y[I];const w=Math.min(v,m),b=c*d,E=b/t**2/w;let D=0;for(let I=n.length-1;I>=0&&D{oe&&(s(L,I),oe=!1),r(L,I,we,Ke,$e)}),D=Se}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Is=`vec3 colormapJet(float x) { + vec3 result; + result.r = x < 0.89 ? ((x - 0.35) / 0.31) : (1.0 - (x - 0.89) / 0.11 * 0.5); + result.g = x < 0.64 ? ((x - 0.125) * 4.0) : (1.0 - (x - 0.64) / 0.27); + result.b = x < 0.34 ? (0.5 + x * 0.5 / 0.11) : (1.0 - (x - 0.34) / 0.31); + return clamp(result, 0.0, 1.0); +} +vec3 colormapCubehelix(float x) { + float xclamp = clamp(x, 0.0, 1.0); + float angle = 2.0 * 3.1415926 * (4.0 / 3.0 + xclamp); + float amp = xclamp * (1.0 - xclamp) / 2.0; + vec3 result; + float cosangle = cos(angle); + float sinangle = sin(angle); + result.r = -0.14861 * cosangle + 1.78277 * sinangle; + result.g = -0.29227 * cosangle + -0.90649 * sinangle; + result.b = 1.97294 * cosangle; + result = clamp(xclamp + amp * result, 0.0, 1.0); + return result; +} +`;/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const ZE=!1;function ig(i,e){return{defineShader(t,n){const s=`prop_${n}`,r=`a_${s}`;t.addAttribute(`${i}`,r),t.addVertexCode(`${i} ${s}() { return ${r}; }`),t.addInitializer(o=>{const a=o.attribute(r),{gl:l}=o;o.vertexShaderInputBinders[s]=a===-1?{enable(){},disable(){},bind(){}}:{enable(c){l.enableVertexAttribArray(a),l.vertexAttribDivisor(a,c)},disable(){l.vertexAttribDivisor(a,0),l.disableVertexAttribArray(a)},bind(c,d){e(l,a,c,d)}}})}}}function Nc(i,e,t,n){return ig(i,(s,r,o,a)=>{s.vertexAttribPointer(r,e,t,n,o,a)})}function Ls(i,e,t){return ig(i,(n,s,r,o)=>{n.vertexAttribIPointer(s,e,t,r,o)})}const sg={rgb:Nc("highp vec3",3,WebGL2RenderingContext.UNSIGNED_BYTE,!0),rgba:Nc("highp vec4",4,WebGL2RenderingContext.UNSIGNED_BYTE,!0),float32:Nc("highp float",1,WebGL2RenderingContext.FLOAT,!1),uint32:Ls("highp uint",1,WebGL2RenderingContext.UNSIGNED_INT),int32:Ls("highp int",1,WebGL2RenderingContext.INT),uint16:Ls("highp uint",1,WebGL2RenderingContext.UNSIGNED_SHORT),int16:Ls("highp int",1,WebGL2RenderingContext.SHORT),uint8:Ls("highp uint",1,WebGL2RenderingContext.UNSIGNED_BYTE),int8:Ls("highp int",1,WebGL2RenderingContext.BYTE)};class eT extends T.O8{constructor(e,t,n,s){super(),this.gl=e,this.annotationType=t,this.rank=n,this.properties=s;const r=this.serializedGeometryBytesPerAnnotation=Ft[t].serializedBytes(n),{offsets:o,serializedBytes:a,propertyGroupBytes:l}=xh(n,r,s);this.serializedBytesPerAnnotation=a,this.propertyOffsets=o,this.propertyGroupBytes=l,this.geometryDataStride=l[0];const c=this.propertyGroupCumulativeBytes=new Array(l.length);c[0]=0;for(let d=1;d{const c=t.map(u=>l.vertexShaderInputBinders[`prop_${n[u].identifier}`]),d=c.length;l.vertexShaderInputBinders.properties={enable(u){for(let h=0;h{const{rank:r,properties:o}=this,a=[],l=s.referencedProperties,c=s.parseResult.code;for(let u=0,h=o.length;u`highp uint partIndex${r}`).join()}) { + highp uint pickID = uPickID; + highp uint pickBaseOffset = getPickBaseOffset(); +${t.map((s,r)=>`highp uint pickOffset${r} = pickBaseOffset + partIndex${r};`).join(` +`)} +`;return t.length===0&&(n+=` + highp uint pickOffset0 = pickBaseOffset; +`),n+=` + vPickID = pickID + pickOffset0; + highp uint selectedIndex = uSelectedIndex; +if (selectedIndex == pickBaseOffset${t.map((s,r)=>` || selectedIndex == pickOffset${r}`).join("")}) { + vColor = vec4(mix(vColor.rgb, vec3(1.0, 1.0, 1.0), 0.75), vColor.a); + } +} +`,e.addVertexCode(n),`setPartIndex(${t.join()})`}get invokeUserMain(){return` +ng_discardValue = false; +userMain(); +if (ng_discardValue) { + gl_Position = vec4(2.0, 0.0, 0.0, 1.0); + return; +} +`}getCrossSectionFadeFactor(){return this.targetIsSliceView?"(clamp(1.0 - 2.0 * abs(0.5 - gl_FragCoord.z), 0.0, 1.0))":"(1.0)"}enable(e,t,n){const{shader:s,parameters:r}=e(t.renderContext.emitter);if(s===null)return;s.bind();const{gl:o}=this,{renderContext:a}=t,{annotationLayer:l}=t;if(vi(o,s,this.shaderControlState,r.parseResult.controls),o.uniform3fv(s.uniform("uSubspaceMatrix"),t.subspaceMatrix),o.uniform1fv(s.uniform("uModelClipBounds"),t.modelClipBounds),o.uniformMatrix4fv(s.uniform("uModelViewProjection"),!1,t.modelViewProjectionMatrix),a.emitPickID&&o.uniform1ui(s.uniform("uPickID"),t.basePickId),a.emitColor){const d=l.state.displayState.color.value;o.uniform3f(s.uniform("uColor"),d[0],d[1],d[2]),o.uniform1ui(s.uniform("uSelectedIndex"),t.selectedIndex)}const c=s.vertexShaderInputBinders.properties;c.enable(1),o.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER,t.buffer.buffer),c.bind(t.count,t.bufferOffset),n(s),c.disable()}getHistogramShader(e){const{histogramShaders:t}=this;let n=t.get(e);if(n===void 0){const{gl:s}=this;n=s.memoize.get(JSON.stringify({t:"propertyHistogramGenerator",propertyType:e}),()=>{const r=new fn(s);return this.defineHistogramShader(r,e),r.build()}),t.set(e,n)}return n}defineHistogramShader(e,t){sg[t].defineShader(e,"histogram",0),e.addOutputBuffer("vec4","out_histogram",0);const s="invlerpForHistogram",r=kl[t];e.addVertexCode(Ss(e,s,r,!1)),e.setVertexMain(` +float x = invlerpForHistogram(prop_histogram()); +if (x < 0.0) x = 0.0; +else if (x > 1.0) x = 1.0; +else x = (1.0 + x * 253.0) / 255.0; +gl_Position = vec4(2.0 * (x * 255.0 + 0.5) / 256.0 - 1.0, 0.0, 0.0, 1.0); +gl_PointSize = 1.0; +`),e.setFragmentMain("out_histogram = vec4(1.0, 1.0, 1.0, 1.0);")}computeHistograms(e,t){const{histogramSpecifications:n}=this.shaderControlState,s=n.properties.value,r=s.length,{properties:o}=this,a=o.length,{propertyOffsets:l}=this,{propertyGroupBytes:c,propertyGroupCumulativeBytes:d}=this,{gl:u}=this;u.enable(WebGL2RenderingContext.BLEND),u.disable(WebGL2RenderingContext.SCISSOR_TEST),u.disable(WebGL2RenderingContext.DEPTH_TEST),u.blendFunc(WebGL2RenderingContext.ONE,WebGL2RenderingContext.ONE);const h=n.getFramebuffers(u),p=n.frameNumber;n.frameNumber=t,u.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER,e.buffer.buffer);for(let m=0;m{for(var s=n>1?void 0:n?nT(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&tT(e,t,s),s};/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const og=!1;class Jn{constructor(e){this.source=e,this.state=Ue.SYSTEM_MEMORY}get gl(){return this.source.gl}copyToGPU(e){this.state=Ue.GPU_MEMORY}freeGPUMemory(e){this.state=Ue.SYSTEM_MEMORY}}function ag(i){if(typeof i!="number"||i<0)throw new Error(`Expected non-negative number as limit, but received: ${JSON.stringify(i)}`);return i}class Zo{constructor({defaultItemLimit:e=Number.POSITIVE_INFINITY,defaultSizeLimit:t=Number.POSITIVE_INFINITY}={}){this.sizeLimit=new _.DN(t,ag),this.itemLimit=new _.DN(e,ag)}}let Vc=class extends hn{constructor(i,e,t,n){super(),this.gl=e,this.frameNumberCounter=t,this.capacities=n,this.visibleChunksChanged=new j.IY,this.pendingChunkUpdates=null,this.pendingChunkUpdatesTail=null,this.chunkUpdateDeadline=null,this.chunkUpdateDelay=30,this.enablePrefetch=new nt(!0,!0);const s=r=>({itemLimit:this.registerDisposer(ft.makeFromExisting(i,r.itemLimit)).rpcId,sizeLimit:this.registerDisposer(ft.makeFromExisting(i,r.sizeLimit)).rpcId});this.initializeCounterpart(i,{gpuMemoryCapacity:s(n.gpuMemory),systemMemoryCapacity:s(n.systemMemory),downloadCapacity:s(n.download),computeCapacity:s(n.compute),enablePrefetch:this.registerDisposer(ft.makeFromExisting(i,this.enablePrefetch)).rpcId})}scheduleChunkUpdate(){const i=this.chunkUpdateDeadline;let e;i===null||Date.now()e){this.chunkUpdateDeadline=null,setTimeout(()=>this.processPendingChunkUpdates(),this.chunkUpdateDelay);break}const s=this.pendingChunkUpdates;if(s==null)break;try{this.applyChunkUpdate(s)&&(t=!0)}finally{if(++n,(this.pendingChunkUpdates=s.nextUpdate)==null){this.pendingChunkUpdatesTail=null;break}}}return t&&this.visibleChunksChanged.dispatch(),n}handleFetch_(i,e){const{resolve:t,reject:n,cancellationToken:s}=e.promise;if(s.isCanceled){n(Je.wS);return}const r=e.key,o=i.chunks.get(r);if(!o){n(new Error(`No chunk found at ${r} for source ${i.constructor.name}`));return}const a=o.data;if(!a){n(new Error(`At ${r} for source ${i.constructor.name}: chunk has no data`));return}t({value:a})}applyChunkUpdate(i){let e=!1;const{rpc:t}=this,n=t.get(i.source);if(n!==void 0){if(og&&console.log(`${Date.now()} Chunk.update processed: ${n.rpcId} ${i.id} ${i.state}`),i.promise!==void 0)this.handleFetch_(n,i);else if(i.id===void 0){for(const s of n.chunks.keys())n.deleteChunk(s);e=!0}else{const s=i.state;if(s===Ue.EXPIRED)n.deleteChunk(i.id);else{let r;const o=i.id;i.new?(r=n.getChunk(i),n.addChunk(o,r)):r=n.chunks.get(o);const a=r.state;if(s!==a)switch(s){case Ue.GPU_MEMORY:r.copyToGPU(this.gl),r.constructor.name!=="ManifestChunk"&&(e=!0);break;case Ue.SYSTEM_MEMORY:a===Ue.GPU_MEMORY&&r.freeGPUMemory(this.gl);break;default:throw new Error(`INTERNAL ERROR: Invalid chunk state: ${Ue[s]}`)}if(s<=Ue.SYSTEM_MEMORY){const{chunkRequesters:l}=n;if(l!==void 0){const c=l.get(o);if(c!==void 0)for(const d of c)d(r)}}}}return e}}flushPendingChunkUpdates(){return this.processPendingChunkUpdates(!0)}async getStatistics(){const i=this.rpc,e=await i.promiseInvoke(GC,{queue:this.rpcId}),t=new Map;for(const[n,s]of e){const r=i.get(n);r!==void 0&&t.set(r,s)}return t}};Vc=_c([Zt(FC)],Vc);function lg(i,e){const t=i.get(e.source);og&&console.log(`${Date.now()} Chunk.update received: ${t.rpcId} ${e.id} ${e.state} with chunkDataSize ${e.chunkDataSize}`);const n=t.chunkManager.chunkQueueManager;if(t.immediateChunkUpdates){n.applyChunkUpdate(e)&&n.visibleChunksChanged.dispatch();return}const s=n.pendingChunkUpdatesTail;s==null?(n.pendingChunkUpdates=e,n.pendingChunkUpdatesTail=e,n.scheduleChunkUpdate()):(s.nextUpdate=e,n.pendingChunkUpdatesTail=e)}pt("Chunk.update",function(i){lg(this,i)}),pp("Chunk.retrieve",function(i,e){return new Promise((t,n)=>{i.promise={resolve:t,reject:n,cancellationToken:e},lg(this,i)})}),pt(zC,function(i){const e=this.get(i.id);for(const t of e.prevStatisticsLayers)t.numVisibleChunksNeeded=0,t.numVisibleChunksAvailable=0,t.numPrefetchChunksNeeded=0,t.numPrefetchChunksAvailable=0;e.prevStatisticsLayers.length=0;for(const t of i.layers){const n=this.get(t.id);if(n===void 0)continue;const s=n.layerChunkProgressInfo;s.numVisibleChunksAvailable=t.numVisibleChunksAvailable,s.numVisibleChunksNeeded=t.numVisibleChunksNeeded,s.numPrefetchChunksAvailable=t.numPrefetchChunksAvailable,s.numPrefetchChunksNeeded=t.numPrefetchChunksNeeded,e.prevStatisticsLayers.push(s)}e.layerChunkStatisticsUpdated.dispatch()});let Bc=class extends hn{constructor(i){super(),this.chunkQueueManager=i,this.memoize=new rg.e,this.prevStatisticsLayers=[],this.layerChunkStatisticsUpdated=new j.IY,this.registerDisposer(i.addRef()),this.initializeCounterpart(i.rpc,{chunkQueueManager:i.rpcId})}get gl(){return this.chunkQueueManager.gl}getChunkSource(i,e){const t=i.encodeOptions(e);t.constructorId=xt(i);const n=(0,f.JB)(t);return this.memoize.get(n,()=>{const s=new i(this,e);return s.initializeCounterpart(this.rpc,{}),s.key=t,s})}};Bc=_c([Zt(UC)],Bc);class on extends hn{constructor(e,t={}){super(),this.chunkManager=e,this.chunks=new Map,this.immediateChunkUpdates=!1}initializeCounterpart(e,t){t.chunkManager=this.chunkManager.rpcId,super.initializeCounterpart(e,t)}get gl(){return this.chunkManager.chunkQueueManager.gl}deleteChunk(e){const t=this.chunks.get(e);t.state===Ue.GPU_MEMORY&&t.freeGPUMemory(this.gl),this.chunks.delete(e)}addChunk(e,t){this.chunks.set(e,t)}getChunk(e){throw new Error("Not implemented.")}invalidateCache(){this.rpc.invoke($C,{id:this.rpcId})}static encodeOptions(e){return{}}}function it(i,e){let t=class extends i{constructor(...n){super(...n);const s=n[1];this.parameters=s.parameters}initializeCounterpart(n,s){s.parameters=this.parameters,super.initializeCounterpart(n,s)}static encodeOptions(n){return Object.assign({parameters:n.parameters},i.encodeOptions(n))}};return t=_c([Zt(e.RPC_ID)],t),t}class Dr extends hn{constructor(e){super(),this.layerChunkProgressInfo=e}}var Rt=G(4242);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const cg=["visibleSegments","segmentEquivalences","temporaryVisibleSegments","temporarySegmentEquivalences","useTemporaryVisibleSegments","useTemporarySegmentEquivalences"];function iT(i,e,t){i.registerDisposer(e.visibleSegments.changed.add(t)),i.registerDisposer(e.segmentEquivalences.changed.add(t))}function sT(i,e,t){i.registerDisposer(e.temporaryVisibleSegments.changed.add(t)),i.registerDisposer(e.temporarySegmentEquivalences.changed.add(t)),i.registerDisposer(e.useTemporaryVisibleSegments.changed.add(t)),i.registerDisposer(e.useTemporarySegmentEquivalences.changed.add(t))}function Sn(i){return`${i.low},${i.high}`}function rT(i){return!!(i.high>>>31)}function dg(i){return i.useTemporaryVisibleSegments.value?i.temporaryVisibleSegments:i.visibleSegments}function oT(i){return i.useTemporarySegmentEquivalences.value?i.temporarySegmentEquivalences:i.segmentEquivalences}function Rs(i,e){const t=dg(i),n=oT(i),s=n.disjointSets.visibleSegmentEquivalencePolicy.value;for(const r of t.unsafeKeys())if(s&Rt.y6.NONREPRESENTATIVE_EXCLUDED){const o=n.get(r);e(r,o)}else{if(!n.disjointSets.isMinElement(r))continue;for(const o of n.setElements(r))s&Rt.y6.REPRESENTATIVE_EXCLUDED&&s&Rt.y6.MAX_REPRESENTATIVE&&rT(o)||e(o,r)}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const mt=40,Ir=.5,ks=-4;function ea(i,e=ks){return(Math.log2(i)-e)/Ir}function aT(i,e=ks){return 2**(i*Ir+e)}function Bi(i,e=2**ks,t){t===void 0&&(t=2**Math.round(Ir*mt+ks)-1);const n=(0,f.JY)(e,t);return new _.DN(i,n)}class Ps{constructor(e=ks){this.visibility=new or,this.changed=new j.IY,this.frameNumber=-1,this.spatialScales=new Map,this.numHistogramRows=1,this.value=new Uint32Array(mt*this.numHistogramRows*2),this.fakeChunkCount=0,this.logScaleOrigin=e}begin(e){e!==this.frameNumber&&(this.value.fill(0),this.frameNumber=e,this.spatialScales.clear(),this.fakeChunkCount=0,this.changed.dispatch())}add(e,t,n,s,r=!1){let{spatialScales:o,numHistogramRows:a,value:l}=this,c=o.get(e);if(c===void 0&&(c=o.size,o.set(e,c)),c>=a){this.numHistogramRows=a*=2;const u=new Uint32Array(a*mt*2);u.set(l),this.value=l=u}const d=c*mt*2+Math.min(Math.max(0,Math.round(ea(t,this.logScaleOrigin))),mt-1);l[d]+=n,l[d+mt]+=s,r&&(this.fakeChunkCount=this.fakeChunkCount+s)}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Fc extends mp{constructor(e,t,n){super(),this.chunkManager=e,this.multiscaleSource=t,this.rpcId=null,this.rpcTransfer={},this.visibleSources=new Map,this.visibleSourcesList_=[];const{renderScaleTarget:s=Bi(1)}=n;this.renderScaleTarget=s,this.renderScaleHistogram=n.renderScaleHistogram,this.transform=n.transform,this.localPosition=n.localPosition,this.rpcTransfer=n.rpcTransfer||{},this.dataHistogramSpecifications=this.registerDisposer(n.dataHistogramSpecifications??new Np((0,_.XZ)([]),(0,_.XZ)([]),(0,_.XZ)([]))),this.registerDisposer(this.dataHistogramSpecifications.visibility.changed.add(this.redrawNeeded.dispatch))}getDataHistogramCount(){return this.dataHistogramSpecifications.visibleHistograms}getSources(e){return this.multiscaleSource.getSources(e)}addSource(e,t){const{visibleSources:n}=this,s=n.get(e);s!==void 0?(++s.refCount,s.chunkTransform=t):(n.set(e,{source:e,refCount:1,chunkTransform:t}),this.visibleSourcesList_.length=0)}removeSource(e){const{visibleSources:t}=this,n=t.get(e);n.refCount!==1?--n.refCount:(t.delete(e),this.visibleSourcesList_.length=0)}get visibleSourcesList(){const{visibleSources:e,visibleSourcesList_:t}=this;if(t.length===0&&e.size!==0){for(const n of e.values())t.push(n);t.sort((n,s)=>Math.abs(n.chunkTransform.chunkToLayerTransformDet)-Math.abs(s.chunkTransform.chunkToLayerTransformDet))}return t}initializeCounterpart(){const e=this.registerDisposer(new Dr(this.layerChunkProgressInfo)),t=this.chunkManager.rpc;e.RPC_TYPE_ID=this.RPC_TYPE_ID,e.initializeCounterpart(t,{localPosition:this.registerDisposer(ft.makeFromExisting(t,this.localPosition)).rpcId,renderScaleTarget:this.registerDisposer(ft.makeFromExisting(t,this.renderScaleTarget)).rpcId,...this.rpcTransfer}),this.rpcId=e.rpcId}get gl(){return this.chunkManager.chunkQueueManager.gl}setGLBlendMode(e,t){t>0?(e.enable(WebGL2RenderingContext.BLEND),e.blendFunc(WebGL2RenderingContext.SRC_ALPHA,WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA)):e.disable(WebGL2RenderingContext.BLEND)}filterVisibleSources(e,t){return NE(e,this,t)}}Fc.prototype.RPC_TYPE_ID=_E;class Fi extends vp{draw(e,t){}isReady(e,t){return!0}}var lT=Object.defineProperty,cT=Object.getOwnPropertyDescriptor,dT=(i,e,t,n)=>{for(var s=n>1?void 0:n?cT(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&lT(e,t,s),s};/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class uT extends kE{}const hT=ar(uT);function pT(i){return{source:i.source.addCounterpartRef(),effectiveVoxelSize:i.effectiveVoxelSize,layerRank:i.layerRank,nonDisplayLowerClipBound:i.nonDisplayLowerClipBound,nonDisplayUpperClipBound:i.nonDisplayUpperClipBound,lowerClipBound:i.lowerClipBound,upperClipBound:i.upperClipBound,lowerClipDisplayBound:i.lowerClipDisplayBound,upperClipDisplayBound:i.upperClipDisplayBound,chunkDisplayDimensionIndices:i.chunkDisplayDimensionIndices,lowerChunkDisplayBound:i.lowerChunkDisplayBound,upperChunkDisplayBound:i.upperChunkDisplayBound,fixedLayerToChunkTransform:i.fixedLayerToChunkTransform,combinedGlobalLocalToChunkTransform:i.combinedGlobalLocalToChunkTransform,chunkLayout:i.chunkLayout.toObject()}}function ta(i){return i.map(e=>e.map(pT))}function Uc(i,e){for(const t of e)for(const{source:n}of t)i.removeSource(n),n.dispose()}let na=class extends hT{constructor(i,e,t,n){super(new yp({parametersConstructor:LE,navigationState:t,update:(o,a)=>{const{invViewMatrix:l,centerDataPosition:c}=o;a.toMat4(l);const{canonicalVoxelFactors:d,voxelPhysicalScales:u}=o.displayDimensionRenderInfo;for(let b=0;b<3;++b)c[b]=l[12+b];const{logicalWidth:h,logicalHeight:p,projectionMat:m,viewportNormalInGlobalCoordinates:g,viewportNormalInCanonicalCoordinates:v}=o,{relativeDepthRange:y}=a;C.pB.ortho(m,-h/2,h/2,p/2,-p/2,-y,y),ip(o,m),ap(o);const{viewMatrix:S}=o;for(let b=0;b<3;++b){const x=g[b]=S[b*4+2];v[b]=x/d[b]}C.eR.normalize(g,g),C.eR.normalize(v,v);let w=0;for(let b=0;b<3;++b){const x=u[b],E=l[b];w+=(x*E)**2}w=Math.sqrt(w),o.pixelSize=w}})),this.chunkManager=i,this.layerManager=e,this.navigationState=t,this.wireFrame=n,this.gl=this.chunkManager.gl,this.viewChanged=new j.IY,this.renderingStale=!0,this.visibleChunksStale=!0,this.visibleLayerList=new Array,this.offscreenFramebuffer=this.registerDisposer(new $n(this.gl,{colorBuffers:vs(this.gl,1),depthBuffer:new xw(this.gl)})),this.histogramInputTextures=[],this.offscreenFramebuffersWithHistograms=[this.offscreenFramebuffer],this.histogramGenerator=hc.get(this.gl),this.updateVisibleLayers=this.registerCancellable((0,Fe.A)(()=>{this.updateVisibleLayersNow()},0)),this.registerDisposer(t),this.registerDisposer(this.projectionParameters),this.registerDisposer(this.projectionParameters.changed.add((o,a)=>{o.displayDimensionRenderInfo!==a.displayDimensionRenderInfo&&this.updateVisibleLayers()}));const s=this.chunkManager.rpc,r=this.sharedProjectionParameters=this.registerDisposer(new So(s,this.projectionParameters));this.initializeCounterpart(s,{chunkManager:i.rpcId,projectionParameters:r.rpcId}),this.registerDisposer(e.layersChanged.add(()=>{this.updateVisibleLayers()})),this.wireFrame.changed.add(this.viewChanged.dispatch),this.viewChanged.add(()=>{this.renderingStale=!0}),this.registerDisposer(i.chunkQueueManager.visibleChunksChanged.add(this.viewChanged.dispatch)),this.updateVisibleLayers()}get displayDimensionRenderInfo(){return this.navigationState.displayDimensionRenderInfo}computeHistograms(i,e){this.histogramGenerator.compute(i,this.offscreenFramebuffer.depthBuffer.texture,this.histogramInputTextures,e,this.chunkManager.chunkQueueManager.frameNumberCounter.frameNumber)}flushBackendProjectionParameters(){this.sharedProjectionParameters.flush()}forEachVisibleChunk(i,e,t){UE(this.projectionParameters.value,i.renderLayer.localPosition.value,i,e,()=>{t(i.curPositionInChunks.join())})}isReady(){if(!this.navigationState.valid)return!1;this.updateVisibleLayers.flush(),this.updateVisibleSources();let i=0,e=0;for(const{visibleSources:t}of this.visibleLayers.values())for(const n of t){const s=Mc(this.projectionParameters.value,n.chunkLayout),{source:r}=n,{chunks:o}=r;this.forEachVisibleChunk(n,s,a=>{const l=o.get(a);++e,l&&l.state===Ue.GPU_MEMORY&&++i})}return i===e}invalidateVisibleSources(){super.invalidateVisibleSources(),this.viewChanged.dispatch()}bindVisibleRenderLayer(i,e){e.push(i.localPosition.changed.add(()=>this.invalidateVisibleChunks())),e.push(i.redrawNeeded.add(this.viewChanged.dispatch)),e.push(i.transform.changed.add(this.updateVisibleLayers)),e.push(i.renderScaleTarget.changed.add(()=>this.invalidateVisibleSources()));const{renderScaleHistogram:t}=i;t!==void 0&&e.push(t.visibility.add(this.visibility)),e.push(i.dataHistogramSpecifications.producerVisibility.add(this.visibility))}updateVisibleLayersNow(){if(this.wasDisposed||!this.navigationState.valid)return!1;const i=Date.now(),{visibleLayers:e,visibleLayerList:t}=this,{displayDimensionRenderInfo:n}=this.projectionParameters.value,s=this.rpc,r={id:this.rpcId};let o=!1;t.length=0;for(const a of this.layerManager.readyRenderLayers())if(a instanceof Fc){t.push(a);let l=e.get(a);if(l===void 0){const c=[],d=new ai;l={messages:d,allSources:this.getTransformedSources(a,d),transformGeneration:a.transform.changed.count,visibleSources:[],disposers:c,lastSeenGeneration:i,displayDimensionRenderInfo:n},c.push(a.messages.addChild(l.messages)),e.set(a.addRef(),l),this.bindVisibleRenderLayer(a,c)}else{l.lastSeenGeneration=i;const c=a.transform.changed.count;if(l.transformGeneration===c&&l.displayDimensionRenderInfo===n)continue;const d=l.allSources;l.allSources=this.getTransformedSources(a,l.messages),Uc(a,d),l.visibleSources.length=0,l.displayDimensionRenderInfo=n,l.transformGeneration=c}r.layerId=a.rpcId,r.sources=ta(l.allSources),r.displayDimensionRenderInfo=n,this.flushBackendProjectionParameters(),s.invoke(VE,r),o=!0}for(const[a,l]of e)l.lastSeenGeneration!==i&&(r.layerId=a.rpcId,s.invoke(BE,r),e.delete(a),Uc(a,l.allSources),(0,T.$F)(l.disposers),a.dispose(),o=!0);return o&&(this.visibleSourcesStale=!0),this.viewChanged.dispatch(),o}invalidateVisibleChunks(){super.invalidateVisibleChunks(),this.viewChanged.dispatch()}get valid(){return this.navigationState.valid}getOffscreenFramebufferWithHistograms(i){const{offscreenFramebuffersWithHistograms:e}=this;let t=e[i];if(t===void 0){const{gl:n,histogramInputTextures:s,offscreenFramebuffer:r}=this;s.lengthi.getSources(n),e,i);for(const n of t)for(const s of n)i.addSource(s.source,s.chunkTransform);return t}};na=dT([Zt(OE)],na);class Lr extends on{constructor(e,t){super(e,t),this.spec=t.spec}static encodeSpec(e){return{chunkDataSize:Array.from(e.chunkDataSize),lowerVoxelBound:Array.from(e.lowerVoxelBound),upperVoxelBound:Array.from(e.upperVoxelBound)}}static encodeOptions(e){const t=on.encodeOptions(e);return t.spec=Lr.encodeSpec(e.spec),t}initializeCounterpart(e,t){t.spec=this.spec,super.initializeCounterpart(e,t)}async fetchChunk(e,t,n=Je.fx){const s=e.join(),r=this.chunks.get(s);if(r!==void 0&&r.state<=Ue.SYSTEM_MEMORY)return t(r);this.addRef();let{chunkRequesters:o}=this;o===void 0&&(o=this.chunkRequesters=new Map);let a,l=o.get(s);l===void 0&&(l=[],o.set(s,l));const c=new Promise(d=>{a=u=>d(t(u)),l.push(a)});try{return await this.rpc.promiseInvoke(FE,{source:this.rpcId,chunkGridPosition:e},n),await c}finally{const d=l.indexOf(a);l.splice(d,1),l.length===0&&o.delete(s),o.size===0&&(this.chunkRequesters=void 0),this.dispose()}}}class ug extends Jn{constructor(e,t){super(e),this.chunkGridPosition=t.chunkGridPosition,this.state=Ue.SYSTEM_MEMORY}}class ia extends T.O8{constructor(e,t){super(),this.gl=e,this.copyVertexPositionsBuffer=ur(this.gl),this.textureCoordinateAdjustment=new Float32Array(4);const n=new fn(e);n.addVarying("vec2","vTexCoord"),n.addUniform("sampler2D","uSampler"),n.addInitializer(s=>{e.uniform1i(s.uniform("uSampler"),0)}),n.addUniform("vec4","uColorFactor"),n.addUniform("vec4","uBackgroundColor"),n.addUniform("mat4","uProjectionMatrix"),n.addUniform("vec4","uTextureCoordinateAdjustment"),n.require(t),n.setFragmentMain(` +vec4 sampledColor = texture(uSampler, vTexCoord); +if (sampledColor.a == 0.0) { + sampledColor = uBackgroundColor; +} +emit(sampledColor * uColorFactor, 0u); +`),n.addAttribute("vec4","aVertexPosition"),n.setVertexMain(` +vTexCoord = uTextureCoordinateAdjustment.xy + 0.5 * (aVertexPosition.xy + 1.0) * uTextureCoordinateAdjustment.zw; +gl_Position = uProjectionMatrix * aVertexPosition; +`),this.shader=this.registerDisposer(n.build())}draw(e,t,n,s,r,o,a,l){const{gl:c,shader:d,textureCoordinateAdjustment:u}=this;u[0]=r,u[1]=o,u[2]=a-r,u[3]=l-o,d.bind(),c.activeTexture(c.TEXTURE0),c.bindTexture(c.TEXTURE_2D,e),c.disable(WebGL2RenderingContext.BLEND),c.uniformMatrix4fv(d.uniform("uProjectionMatrix"),!1,t),c.uniform4fv(d.uniform("uColorFactor"),n),c.uniform4fv(d.uniform("uBackgroundColor"),s),c.uniform4fv(d.uniform("uTextureCoordinateAdjustment"),u);const h=d.attribute("aVertexPosition");this.copyVertexPositionsBuffer.bindToVertexAttrib(h,2),c.drawArrays(c.TRIANGLE_FAN,0,4),c.disableVertexAttribArray(h),c.bindTexture(c.TEXTURE_2D,null)}static get(e,t){return e.memoize.get(`sliceview/SliceViewRenderHelper:${xt(t)}`,()=>new ia(e,t))}}class fT{constructor(e){this.chunkManager=e}}function sa(i,e,t,n,s){n.clearMessages();const r=y=>(n.addMessage({severity:Tn.error,message:y}),[]);if(e.error!==void 0)return r(e.error);const o=e.rank,a=e.unpaddedRank,{displayDimensionIndices:l,displayRank:c,canonicalVoxelFactors:d}=i,u=Zh(e,l),{displayToLayerDimensionIndices:h}=u,p=new Float32Array(c*a),{modelToRenderLayerTransform:m}=e;for(let y=0;y{const{chunkSource:w}=S,{spec:b}=w,{lowerClipBound:x=b.lowerVoxelBound,upperClipBound:E=b.upperVoxelBound}=S,D=po(e,S.chunkToMultiscaleTransform),{chunkDataSize:I}=b,{channelToChunkDimensionIndices:L}=D,N=new Float32Array(a),k=new Float32Array(a);N.set(x),k.set(E);const O=L.length,{channelSpaceShape:V}=e;for(let be=0;beS.map(w=>y(w)))}catch(y){for(const x of g)for(const{chunkSource:E}of x)E.dispose();const{globalDimensionNames:S}=i,b=`Cannot render (${Array.from(i.displayDimensionIndices.filter(x=>x!==-1),x=>S[x]).join(",\xA0")}) cross section: ${y.message}`;return r(b)}}var gT=Object.defineProperty,mT=Object.getOwnPropertyDescriptor,$c=(i,e,t,n)=>{for(var s=n>1?void 0:n?mT(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&gT(e,t,s),s};/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function hg(i){let e=0;const{typeToIds:t}=i;for(const n of Xt)e+=Tr(n).pickIdsPerInstance*t[n].length;return e}class pg{constructor(e){this.bufferValid=!1,this.numPickIds=0,this.serializedAnnotations={data:e.data,typeToIds:e.typeToIds,typeToOffset:e.typeToOffset,typeToIdMaps:e.typeToIdMaps}}freeGPUMemory(e){const{buffer:t}=this;t!==void 0&&(t.dispose(),this.bufferValid=!1,this.buffer=void 0)}}class vT extends Jn{constructor(e,t){super(e),t.data!==void 0&&(this.data=new pg(t))}freeGPUMemory(e){super.freeGPUMemory(e);const{data:t}=this;t!==void 0&&t.freeGPUMemory(e)}dispose(){this.data=void 0}}class fg extends ug{constructor(e,t){super(e,t),t.data!==void 0&&(this.data=new pg(t))}freeGPUMemory(e){super.freeGPUMemory(e);const{data:t}=this;t!==void 0&&t.freeGPUMemory(e)}dispose(){this.data=void 0}}let ra=class extends Lr{constructor(i,e){super(i,e),this.immediateChunkUpdates=!0,(this.parent=e.parent).spatiallyIndexedSources.add(this);const{rank:n,chunkDataSize:s}=this.spec,r=this.multiscaleToChunkTransform=new Float32Array((n+1)**2);De.DI(r,n+1,this.spec.chunkToMultiscaleTransform,n+1,n+1);for(let o=0;ot&&(a+=n,i.typeToOffset[r]=a),s.set(i.data.subarray(o,o+i.typeToIds[r].length*e[r].serializedBytes),a)}return s}function Wc(i,e,t,n,s,r,o,a){const l=i.typeToOffset[t];let c=l,d=l;const{propertyGroupBytes:u}=e[t],h=u.length,p=i.typeToIds[t].length;for(let m=0;m0}getSources(e){throw new Error("not implemented")}initializeCounterpart(e,t){this.metadataChunkSource.initializeCounterpart(e,{});for(const n of this.segmentFilteredSources)n.initializeCounterpart(e,{});t.segmentFilteredSource=this.segmentFilteredSources.map(n=>n.addCounterpartRef()),t.metadataChunkSource=this.metadataChunkSource.addCounterpartRef(),t.chunkManager=this.chunkManager.rpcId,super.initializeCounterpart(e,t)}add(e,t=!0){e.id=Vl();const n=new Li(e.id);return n.value=e,this.references.set(n.id,n),n.registerDisposer(()=>{this.references.delete(n.id)}),this.applyLocalUpdate(n,!1,t,e),n}applyLocalUpdate(e,t,n,s){const{localUpdates:r}=this,{id:o}=e;let a=this.localUpdates.get(o);const l=e.value;if(l==null)throw new Error("Cannot create local update from null annotation");if(a===void 0?(a={type:l.type,reference:e.addRef(),existingAnnotation:t?l:void 0,pendingCommit:void 0,commitInProgress:void 0},r.set(o,a),this.forEachPossibleChunk(l,c=>{const{data:d}=c;if(d===void 0)return;const u=l.type;aa(d,u,o,this.annotationPropertySerializers)}),s!==null&&oa(this.temporary.data,s,this.annotationPropertySerializers)):(s===null?aa(this.temporary.data,l.type,l.id,this.annotationPropertySerializers):oa(this.temporary.data,s,this.annotationPropertySerializers),e.value=s),n)if(a.commitInProgress!==void 0)a.pendingCommit=s;else{if(s===null&&a.existingAnnotation===void 0){r.delete(o),a.reference.dispose();return}this.sendCommitRequest(a,s)}this.notifyChanged(e.id,s||void 0)}sendCommitRequest(e,t){this.updateCommitsInProgress(1),e.commitInProgress=t,this.rpc.invoke(JE,{id:this.rpcId,annotationId:e.existingAnnotation&&e.reference.id,newAnnotation:t})}delete(e){this.applyLocalUpdate(e,!0,!0,null)}update(e,t){this.applyLocalUpdate(e,!0,!1,t)}notifyChanged(e,t){const n=this.references.get(e),s=this.metadataChunkSource.chunks.get(e);s!==void 0&&(s.annotation=t||null),n!==void 0&&(n.value=t||null,n.changed.dispatch()),this.chunkManager.chunkQueueManager.visibleChunksChanged.dispatch()}commit(e){this.applyLocalUpdate(e,!0,!0,e.value)}getReference(e){let t=this.references.get(e);if(t!==void 0)return t.addRef();t=new Li(e),this.references.set(e,t),this.rpc.invoke(WE,{id:this.rpcId,annotation:e}),t.registerDisposer(()=>{this.references.delete(e),this.rpc.invoke(HE,{id:this.rpcId,annotation:e})});const n=this.metadataChunkSource.chunks.get(e);return n!==void 0&&(t.value=n.annotation),t}forEachPossibleChunk(e,t){const{relatedSegments:n}=e;if(n!==void 0){const l=n.length,{segmentFilteredSources:c}=this;for(let d=0;d{const{data:o}=r;o!==void 0&&oa(o,t,this.annotationPropertySerializers)});const{reference:n}=e,{id:s}=n;n.value=t||null,n.changed.dispatch(),n.dispose(),this.localUpdates.delete(s)}*[Symbol.iterator](){}}pt(jE,function(i){const e=this.get(i.id),t=i.annotationId,n=i.error;if(n!==void 0)e.handleFailedUpdate(t,n);else{const s=Lh(i.newAnnotation);e.handleSuccessfulUpdate(t,s)}});var kr=G(8795);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const mg={offset:0,completions:[]};function yi(i,e){return e.offset+=i,e}function Hc(i,e){const t=[];for(const n of e)n.startsWith(i)&&t.push({value:n});return t.sort((n,s)=>(0,kr.e)(n.value,s.value)),t}function Ht(i,e,t,n){const s=[];for(const r of e){const o=t(r);o.startsWith(i)&&s.push({value:o,description:n(r)})}return s.sort((r,o)=>(0,kr.e)(r.value,o.value)),s}async function bT(i,e,t){if(i.startsWith("{"))return mg;const s=i.match(/^(?:(.*)[&;])?([^&;]*)$/)[2],r=i.length-s.length,o=s.indexOf("=");if(o===-1){const a=await e(s);return{offset:a.offset+r,completions:a.completions.map(l=>({...l,value:`${l.value}=`}))}}return yi(r+o+1,await t(s.substring(0,o),s.substring(o+1)))}async function vg(i,e){return bT(i,async t=>{const n=[];for(const s of e){const r=s.key;r.value.startsWith(t)&&n.push(r)}return{offset:0,completions:n}},async(t,n)=>{for(const s of e)if(s.key.value===t)return{offset:0,completions:s.values.filter(r=>r.value.startsWith(n))};return mg})}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Jc extends Error{constructor(e){super(`Redirected to: ${e}`),this.redirectTarget=e}}function yg(i,e){e===void 0&&(i.indexOf("/")===-1?e=":":e="/");const t=i.lastIndexOf(e);return t===-1?0:t+1}function CT(i,e){const t=yg(i,e);return i.substring(t)}var As=(i=>(i[i.annotations=0]="annotations",i[i.equivalences=1]="equivalences",i))(As||{});function Sg(){return{url:"",transform:void 0,enableDefaultSubsources:!0,subsources:new Map}}class Jt extends T.O8{normalizeUrl(e){return e.url}convertLegacyUrl(e){return e.url}async completeUrl(e){throw null}}const bg="local://annotations",jc="local://equivalences";class wT extends Jt{get description(){return"Local in-memory"}async get(e){switch(e.url){case bg:{const{transform:t}=e;let n;if(t===void 0){const s=e.globalCoordinateSpace.value,{rank:r,names:o,scales:a,units:l}=s,c=Oe({rank:r,scales:a,units:l,names:o.map((u,h)=>`${h}`)}),d=Oe({rank:r,scales:a,units:l,names:o});n={rank:r,sourceRank:r,inputSpace:c,outputSpace:d,transform:(0,De.DA)(Float64Array,r+1)}}else n=wt(ki);return{modelTransform:n,canChangeModelSpaceRank:!0,subsources:[{id:"default",default:!0,subsource:{local:0}}]}}case jc:return{modelTransform:wt(ki),canChangeModelSpaceRank:!1,subsources:[{id:"default",default:!0,subsource:{local:1}}]}}throw new Error("Invalid local data source URL")}async completeUrl(e){return{offset:0,completions:Ht(e.providerUrl,[{value:"annotations",description:"Annotations stored in the JSON state"},{value:"equivalences",description:"Segmentation equivalence graph stored in the JSON state"}],t=>t.value,t=>t.description)}}}const Cg=/^(?:([a-zA-Z][a-zA-Z0-9-+_]*):\/\/)?(.*)$/;class xT extends T.O8{constructor(e){super(),this.credentialsManager=e,this.dataSources=new Map([["local",new wT]])}register(e,t){this.dataSources.set(e,this.registerDisposer(t))}getProvider(e){const t=e.match(Cg);if(t===null||t[1]===void 0)throw new Error('Data source URL must have the form "://".');const[,n,s]=t,r=this.dataSources.get(n);if(r===void 0)throw new Error(`Unsupported data source: ${JSON.stringify(n)}.`);return[r,s,n]}async get(e){const t=new Set,{cancellationToken:n=Je.fx}=e;let s=e.url;for(;;){const[r,o,a]=this.getProvider(e.url);t.add(e.url);try{return r.get({...e,url:s,providerProtocol:a,providerUrl:o,registry:this,cancellationToken:n,credentialsManager:this.credentialsManager})}catch(l){if(l instanceof Jc){const c=l.redirectTarget;if(t.has(c))throw Error(`Layer source redirection contains loop: ${JSON.stringify(Array.from(t))}`);if(t.size>=10)throw Error(`Too many layer source redirections: ${JSON.stringify(Array.from(t))}`);s=c;continue}throw l}}}convertLegacyUrl(e){try{const[t,n,s]=this.getProvider(e.url);return t.convertLegacyUrl({...e,providerUrl:n,providerProtocol:s,registry:this})}catch{return e.url}}normalizeUrl(e){try{const[t,n,s]=this.getProvider(e.url);return t.normalizeUrl({...e,providerUrl:n,providerProtocol:s,registry:this})}catch{return e.url}}async completeUrl(e){const{url:t,cancellationToken:n=Je.fx}=e,s=t.match(Cg),r=s[1];if(r===void 0)return Promise.resolve({offset:0,completions:Ht(t,this.dataSources,([a])=>`${a}://`,([,a])=>a.description)});const o=this.dataSources.get(r);if(o!==void 0){const a=await o.completeUrl({registry:this,url:t,providerUrl:s[2],chunkManager:e.chunkManager,cancellationToken:n,credentialsManager:this.credentialsManager});return yi(r.length+3,a)}throw null}suggestLayerName(e){let[t,n]=this.getProvider(e);n.endsWith("/")&&(n=n.substring(0,n.length-1));const s=t.suggestLayerName;return s!==void 0?s(n):CT(n)}findSourceGroup(e){const[t,n,s]=this.getProvider(e);return(t.findSourceGroup||yg)(n)+s.length+3}}var la=G(4022);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function ET(i){return typeof i=="boolean"?{enabled:i}:((0,f.Rf)(i),{enabled:(0,f.MM)(i,"enabled",f.aO)})}function Pr(i,e=void 0){return typeof i=="string"?{url:i,transform:e,enableDefaultSubsources:!0,subsources:new Map}:((0,f.Rf)(i),{url:(0,f.cQ)(i,"url",f.zr),transform:(0,f.cQ)(i,"transform",jh)||e,enableDefaultSubsources:(0,f.MM)(i,"enableDefaultSubsources",f.aO,!0),subsources:(0,f.MM)(i,"subsources",t=>(0,f.vS)(t,ET),new Map),state:(0,f.MM)(i,"state",f.Rf)})}function TT(i){return i.enabled}function wg(i){const e=Yh(i.transform),t={};let n=!0;for(const[s,r]of i.subsources){const o=TT(r);o!==void 0&&(t[s]=o,n=!1)}return e===void 0&&n&&i.enableDefaultSubsources===!0&&i.state===void 0?i.url:{url:i.url,transform:e,subsources:n?void 0:t,enableDefaultSubsources:i.enableDefaultSubsources===!0?void 0:!1,state:i.state}}class DT{constructor(e,t,n,s,r){this.loadedDataSource=e,this.subsourceEntry=t,this.subsourceSpec=n,this.subsourceIndex=s,this.activated=void 0,this.guardValues=[],this.messages=new ai,this.isActiveChanged=new j.IY;let o;n===void 0||n.enabled===void 0?o=t.default&&r:o=n.enabled;const a=e.dataSource.modelTransform.sourceRank;let{modelSubspaceDimensionIndices:l}=t;if(l===void 0){l=new Array(a);for(let d=0;dnew DT(this,r,s.get(r.id),o,this.enableDefaultSubsources))}get enabledSubsources(){return this.subsources.filter(e=>e.enabled)}get layer(){return this.layerDataSource.layer}disposed(){for(const e of this.subsources){const{activated:t}=e;t!==void 0&&(e.activated=void 0,t.dispose())}}}class IT extends T.O8{constructor(e,t=void 0){super(),this.layer=e,this.changed=new j.IY,this.messages=new ai,this.loadState_=void 0,this.specGeneration=-1,this.refCounted_=void 0,this.registerDisposer(this.changed.add(e.dataSourcesChanged.dispatch)),this.registerDisposer(e.messages.addChild(this.messages)),t===void 0?this.spec_=Sg():this.spec=t}get spec(){const{loadState:e}=this;if(e!==void 0&&e.error===void 0){const t=this.changed.count;t!==this.specGeneration&&(this.specGeneration=t,this.spec_={url:this.spec.url,transform:e.transform.spec,enableDefaultSubsources:e.enableDefaultSubsources,subsources:new Map(Array.from(e.subsources,n=>{const s=e.enableDefaultSubsources&&n.subsourceEntry.default;return[n.subsourceEntry.id,{enabled:n.enabled!==s?n.enabled:void 0}]})),state:this.spec.state})}return this.spec_}get loadState(){return this.loadState_}set spec(e){const{layer:t}=this;if(this.messages.clearMessages(),e.url.length===0){if(t.dataSources.length!==1){const l=t.dataSources.indexOf(this);if(l!==-1){t.dataSources.splice(l,1),t.dataSourcesChanged.dispatch(),this.dispose();return}}this.spec_=e,this.refCounted_!==void 0&&(this.refCounted_.dispose(),this.refCounted_=void 0,this.loadState_=void 0,this.changed.dispatch());return}const n=new T.O8,s=n.registerDisposer((0,T.K9)(t.markLoading()));this.refCounted_!==void 0&&(this.refCounted_.dispose(),this.loadState_=void 0),this.refCounted_=n,this.spec_=e;const r=t.manager.chunkManager,o=t.manager.dataSourceProviderRegistry,a=new Je.Qi;this.messages.addMessage({severity:Tn.info,message:"Loading data source"}),o.get({chunkManager:r,url:e.url,cancellationToken:a,globalCoordinateSpace:t.manager.root.coordinateSpace,transform:e.transform,state:e.state}).then(l=>{if(n.wasDisposed)return;this.messages.clearMessages();const c=n.registerDisposer(new Yc(this,l,e));c.registerDisposer(t.addCoordinateSpace(c.transform.outputSpace)),c.registerDisposer(c.transform.changed.add(this.changed.dispatch)),this.loadState_=c,c.registerDisposer(c.enabledSubsourcesChanged.add(this.changed.dispatch)),this.changed.dispatch(),l.state&&n.registerDisposer(l.state.changed.add(()=>{this.spec.state=l.state?.toJSON(),t.specificationChanged.dispatch()})),s()}).catch(l=>{this.wasDisposed||(this.loadState_={error:l},this.messages.clearMessages(),this.messages.addMessage({severity:Tn.error,message:l.message}),this.changed.dispatch())}),n.registerDisposer(()=>{a.cancel()}),this.changed.dispatch()}disposed(){const e=this.refCounted_;e!==void 0&&e.dispose()}toJSON(){const{loadState:e}=this;return e===void 0||e.error!==void 0?wg(this.spec):wg({url:this.spec.url,transform:e.transform.spec,enableDefaultSubsources:e.enableDefaultSubsources,subsources:new Map(Array.from(e.subsources,t=>{const n=e.enableDefaultSubsources&&t.subsourceEntry.default;return[t.subsourceEntry.id,{enabled:t.enabled!==n?t.enabled:void 0}]})),state:this.spec.state})}}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Ui={side:"right",col:0,row:1/0,flex:1,size:300,minSize:100,visible:!1};class Si{constructor(e=Ui,t=e){this.defaultValue=e,this.value=t,this.changed=new j.HN,this.locationChanged=new j.HN,this.locationChanged.add(this.changed.dispatch);const n=this;this.watchableVisible={get value(){return n.visible},set value(s){n.visible=s},changed:n.locationChanged}}toJSON(e=this.defaultValue){const t={},{value:n}=this;for(const s in n)n[s]!==e[s]&&(t[s]=n[s]);return t}get visible(){return this.value.visible}set visible(e){const{value:t}=this;t.visible!==e&&(this.value={...t,visible:e},this.locationChanged.dispatch())}reset(){this.value!==this.defaultValue&&(this.value=this.defaultValue,this.locationChanged.dispatch())}restoreState(e,t=this.defaultValue){if(e===void 0)return;(0,f.Rf)(e);const n={side:(0,f.MM)(e,"side",s=>{if(s!=="left"&&s!=="right"&&s!=="top"&&s!=="bottom")throw new Error(`Expected "left", "right", "top", or "bottom", but received: ${JSON.stringify(s)}`);return s},t.side),col:(0,f.MM)(e,"col",f.zo,t.col),row:(0,f.MM)(e,"row",f.zo,t.row),flex:(0,f.MM)(e,"flex",f.zo,t.flex),size:(0,f.MM)(e,"size",f.We,t.size),visible:(0,f.MM)(e,"visible",f.aO,t.visible),minSize:t.minSize};this.value=n,this.locationChanged.dispatch()}}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const ca="tab",xg="tabs",Eg="panels",LT={...Ui,row:0},Tg={...Ui,visible:!0,row:0};class Ar extends T.O8{constructor(e){super(),this.panels=e,this.layer=this.panels.layer,this.location=new Si(Tg),this.tabsChanged=new j.HN,this.selectedTab=new _.B0(void 0),this.tabs=[]}initialize(){const{panels:e}=this;this.tabsChanged.add(e.specificationChanged.dispatch),this.selectedTab.changed.add(e.specificationChanged.dispatch),this.location.changed.add(()=>{e.specificationChanged.dispatch();const{layer:t}=this,{selectedLayer:n}=t.manager.root;if(n.layer?.layer!==t||this!==t.panels.panels[0])return;const s=this.location.value;n.location.value!==s&&(n.location.value=s,n.location.locationChanged.dispatch())}),this.location.locationChanged.add(()=>{this.location.visible||this!==this.panels.panels[0]&&this.panels.removePanel(this)});for(const t of this.tabs){const{hidden:n}=this.layer.tabs.options.get(t);n&&this.registerDisposer(n.changed.add(()=>{this.panels.updateTabs(),this.tabsChanged.dispatch()}))}}normalizeTabs(){const{tabs:e}=this;if(e.length===0){this.selectedTab.value=void 0;return}const t=this.layer.tabs.options,n=o=>t.get(o).order??0;e.sort((o,a)=>n(o)-n(a));const{selectedTab:s}=this,r=s.value;(r===void 0||!e.includes(r))&&(s.value=e[0])}pin(){const{layer:e}=this,{selectedLayer:t}=e.manager.root;if(t.layer?.layer!==e||this!==e.panels.panels[0]||this.tabs.length===0)return;const{panels:n}=this,s=e.registerDisposer(new Ar(n));n.panels.splice(0,1,s),n.panels.push(this),n.updateTabs(),s.initialize(),t.layerManager.layersChanged.dispatch(),this.panels.specificationChanged.dispatch()}unpin(){const{panels:e}=this,t=e.panels.indexOf(this);if(t===-1||t===0)return;const{layer:n}=this,{selectedLayer:s}=n.manager.root,r=s.layer?.layer;s.visible&&r!=null&&r!==n&&r.panels.panels[0].pin(),e.panels.splice(t,1);const[o]=e.panels.splice(0,1,this);if(this.explicitTabs===void 0)n.unregisterDisposer(o);else{e.panels.push(o);for(let a=1,l=e.panels.length;a(0,f.$v)(o,a=>{(0,f.Rf)(a);const l=new Ar(this);l.location.restoreState(a),l.location.visible&&(l.selectedTab.value=(0,f.MM)(a,ca,f.zr),l.explicitTabs=(0,f.MM)(a,xg,c=>{const d=new Set;for(const u of(0,f.si)(c))r.has(u)&&(r.delete(u),d.add(u));return d}),l.explicitTabs===void 0?(l.tabs=Array.from(r),r.clear()):l.tabs=Array.from(l.explicitTabs),l.tabs.length!==0&&(l.normalizeTabs(),n.registerDisposer(l),l.initialize(),t.push(l)))})),t[0].tabs=Array.from(r),t[0].normalizeTabs(),this.panels[0].initialize()}removePanel(e){if(this.updating)return;const t=this.panels.indexOf(e);this.panels.splice(t,1),this.layer.unregisterDisposer(e),this.updateTabs()}updateTabs(){const{layer:e}=this,{tabs:t}=e,n=new Set(t.options.keys()),{panels:s}=this;this.updating=!0;const r=o=>{const a=o.tabs;if(o.explicitTabs===void 0)o.tabs=Array.from(n),n.clear();else{o.tabs=Array.from(o.explicitTabs);for(const l of o.tabs)n.delete(l)}(0,F.r1)(a,o.tabs)||(o.normalizeTabs(),o.tabsChanged.dispatch())};for(let o=1;o1){const n=[];for(let s=1,r=e.length;sthis.updateDataSubsourceActivations()),this.messages.changed.add(this.layersChanged.dispatch);for(const t of Ag)this.tabs.add(t.id,{label:t.label,order:t.order,getter:()=>t.getter(this)})}get localPosition(){return this.managedLayer.localPosition}get localVelocity(){return this.managedLayer.localVelocity}get localCoordinateSpaceCombiner(){return this.managedLayer.localCoordinateSpaceCombiner}get localCoordinateSpace(){return this.managedLayer.localCoordinateSpace}get type(){return this.constructor.type}dispatchLayerEvent(e){this.layerEventListeners.get(e)?.dispatch()}registerLayerEvent(e,t){const{layerEventListeners:n}=this;let s=n.get(e);s||(s=new j.HN,n.set(e,s));const r=s.add(t);return()=>r()}initializeSelectionState(e){e.generation=-1,e.localPositionValid=!1,e.localPosition=ps,e.localCoordinateSpace=void 0,e.annotationId=void 0,e.annotationType=void 0,e.annotationBuffer=void 0,e.annotationIndex=void 0,e.annotationCount=void 0,e.annotationSourceIndex=void 0,e.annotationSubsource=void 0,e.annotationPartIndex=void 0,e.value=void 0}resetSelectionState(e){e.localPositionValid=!1,e.annotationId=void 0,e.value=void 0}selectionStateFromJson(e,t){const n=e.localCoordinateSpace=this.localCoordinateSpace.value,{rank:s}=n;if(s!==0){const o=(0,f.MM)(t,Qc,a=>(0,f.Xu)(new Float32Array(s),a,f.zo));o===void 0?e.localPositionValid=!1:(e.localPositionValid=!0,e.localPosition=o)}(e.annotationId=(0,f.MM)(t,"annotationId",f.zr))!==void 0&&(e.annotationSourceIndex=(0,f.MM)(t,"annotationSource",f.bX,0),e.annotationPartIndex=(0,f.MM)(t,"annotationPart",f.bX),e.annotationSubsource=(0,f.MM)(t,"annotationSubsource",f.zr)),e.value=t.value}displaySelectionState(e,t,n){return!1}selectionStateToJson(e,t){const n={};if(e.localPositionValid){const{localPosition:s}=e;s.length>0&&(n.localPosition=Array.from(s))}return e.annotationId!==void 0&&(n.annotationId=e.annotationId,n.annotationPart=e.annotationPartIndex,n.annotationSource=e.annotationSourceIndex,n.annotationSubsource=e.annotationSubsource),e.value!=null&&(n.value=e.value),n}captureSelectionState(e,t){e.localCoordinateSpace=this.localCoordinateSpace.value;const n=this.localPosition.value,{localPosition:s}=e;s.length!==n.length?e.localPosition=n.slice():s.set(n),e.localPositionValid=!0,e.value=this.getValueAt(t.position,t)}copySelectionState(e,t){e.generation=t.generation,e.localPositionValid=t.localPositionValid,e.localCoordinateSpace=t.localCoordinateSpace;const n=t.localPosition,{localPosition:s}=e;s.length!==n.length?e.localPosition=n.slice():e.localPosition.set(n),e.annotationId=t.annotationId,e.annotationType=t.annotationType,e.annotationBuffer=t.annotationBuffer,e.annotationIndex=t.annotationIndex,e.annotationCount=t.annotationCount,e.annotationSourceIndex=t.annotationSourceIndex,e.annotationSubsource=t.annotationSubsource,e.annotationPartIndex=t.annotationPartIndex,e.value=t.value}get isReady(){return this.loadingCounter===0}get manager(){return this.managedLayer.manager}canAddDataSource(){return!0}addDataSource(e){const t=new IT(this,e);return this.dataSources.push(t),this.dataSourcesChanged.dispatch(),t}activateDataSubsources(e){}updateDataSubsourceActivations(){function*e(){for(const t of this.dataSources){const{loadState:n}=t;if(!(n===void 0||n.error!==void 0))for(const s of n.subsources)if(s.enabled)yield s;else{const{activated:r}=s;s.messages.clearMessages(),r!==void 0&&(r.dispose(),s.activated=void 0,n.activatedSubsourcesChanged.dispatch())}}}this.activateDataSubsources(e.call(this))}decrementLoadingCounter(){--this.loadingCounter===0&&this.readyStateChanged.dispatch()}markLoading(){const e=this.localCoordinateSpaceCombiner.retain(),t=this.manager.root.coordinateSpaceCombiner.retain();return++this.loadingCounter===1&&this.readyStateChanged.dispatch(),()=>{e(),t(),this.decrementLoadingCounter()}}addCoordinateSpace(e){const t=this.manager.root.coordinateSpaceCombiner.bind(e),n=this.localCoordinateSpaceCombiner.bind(e);return()=>{t(),n()}}initializationDone(){const e=this.selectionState={};this.initializeSelectionState(e),this.decrementLoadingCounter()}getLegacyDataSourceSpecifications(e,t,n,s){return e===void 0?[]:[Pr(e,n)]}getDataSourceSpecifications(e){let t,n=(0,f.cQ)(e,kg,r=>Array.isArray(r)?r.map(o=>Pr(o)):typeof r=="object"?[Pr(r)]:(t=r,[]));const s=(0,f.cQ)(e,AT,PC);return n.push(...this.getLegacyDataSourceSpecifications(t,e,s,n)),n=n.filter(r=>r.url),n.length===0&&n.push(Sg()),n}restoreState(e){this.tool.restoreState(e[Dg]),this.panels.restoreState(e),this.localCoordinateSpace.restoreState(e[Rg]),this.localPosition.restoreState(e[Qc]),this.localVelocity.restoreState(e[Lg]),this.toolBinder.restoreState(e[Ig]),this.constructor.supportsPickOption&&this.pick.restoreState(e[Pg]);for(const t of this.getDataSourceSpecifications(e))this.addDataSource(t)}addRenderLayer(e){this.renderLayers.push(e);const{layersChanged:t}=this;return e.layerChanged.add(t.dispatch),e.userLayer=this,t.dispatch(),()=>this.removeRenderLayer(e)}removeRenderLayer(e){const{renderLayers:t,layersChanged:n}=this,s=t.indexOf(e);if(s===-1)throw new Error("Attempted to remove invalid RenderLayer");t.splice(s,1),e.layerChanged.remove(n.dispatch),e.userLayer=void 0,e.dispose(),n.dispatch()}disposed(){const{layersChanged:e}=this;(0,T.$F)(this.dataSources);for(const t of this.renderLayers)t.layerChanged.remove(e.dispatch),t.dispose();this.renderLayers.length=0,super.disposed()}getValueAt(e,t){let n;const{renderLayers:s}=this,{pickedRenderLayer:r}=t;if(r!==null&&s.indexOf(r)!==-1&&(n=r.transformPickedValue(t),n=this.transformPickedValue(n),n!=null))return n;for(const o of s)if(n=o.getValueAt(e),n!=null)break;return this.transformPickedValue(n)}transformPickedValue(e){return e}toJSON(){return{type:this.type,[kg]:NT(this.dataSources),[Dg]:this.tool.toJSON(),[Ig]:this.toolBinder.toJSON(),[Rg]:this.localCoordinateSpace.toJSON(),[Qc]:this.localPosition.toJSON(),[Lg]:this.localVelocity.toJSON(),[Pg]:this.pick.toJSON(),...this.panels.toJSON()}}handleAction(e,t){}selectedValueToJson(e){return e}selectedValueFromJson(e){return e}setLayerPosition(e,t){const{globalPosition:n}=this.manager.root,{localPosition:s}=this;(0,F.b8)(n.value,t,e.globalToRenderLayerDimensions),(0,F.b8)(s.value,t,e.localToRenderLayerDimensions),s.changed.dispatch(),n.changed.dispatch()}}Rn.supportsPickOption=!1;function NT(i){if(i.length!==0)return i.length===1?i[0].toJSON():i.map(e=>e.toJSON())}class Kc extends T.O8{constructor(e,t){super(),this.manager=t,this.localCoordinateSpace=new zl,this.localCoordinateSpaceCombiner=new Ql(this.localCoordinateSpace,rr),this.localPosition=this.registerDisposer(new ui(this.localCoordinateSpace)),this.localVelocity=this.registerDisposer(new gc(this.localCoordinateSpace)),this.nonArchivedLayerIndex=-1,this.readyStateChanged=new j.IY,this.layerChanged=new j.IY,this.specificationChanged=new j.IY,this.containers=new Set,this.layer_=null,this.visible=!0,this.archived=!1,this.name_=e,this.registerDisposer(new mc(this.manager.root.display,this.localPosition,this.localVelocity))}get layer(){return this.layer_}set layer(e){const t=this.layer_;if(t!=null&&(this.unregisterUserLayer(),t.dispose()),this.layer_=e,e!=null){const n=[e.layersChanged.add(this.layerChanged.dispatch),e.readyStateChanged.add(this.readyStateChanged.dispatch),e.specificationChanged.add(this.specificationChanged.dispatch)];this.unregisterUserLayer=()=>{n.forEach(s=>s())},this.readyStateChanged.dispatch(),this.layerChanged.dispatch()}}isReady(){const{layer:e}=this;return e?.isReady}get name(){return this.name_}set name(e){e!==this.name_&&(this.name_=e,this.layerChanged.dispatch())}get supportsPickOption(){const e=this.layer;return e!==null&&e.constructor.supportsPickOption}get pickEnabled(){const e=this.layer;return e!==null&&e.constructor.supportsPickOption&&e.pick.value}set pickEnabled(e){const t=this.layer;t!==null&&t.constructor.supportsPickOption&&(t.pick.value=e)}toJSON(){const e=this.layer;if(e===null)return;const t=e.toJSON();return t.name=this.name,this.visible||(this.archived?t.archived=!0:t.visible=!1),t}setVisible(e){if(e!==this.visible){if(e&&this.archived){this.visible=!0,this.setArchived(!1);return}this.visible=e,this.layerChanged.dispatch()}}setArchived(e){if(this.archived!==e){if(e===!0){this.visible=!1,this.archived=!0;for(const{layerManager:t}of this.manager.root.subsets)t.has(this)&&t.removeManagedLayer(this)}else{for(const{layerManager:t}of this.manager.root.subsets)t.has(this)||t.addManagedLayer(this.addRef());this.archived=!1}this.layerChanged.dispatch()}}disposed(){this.layer=null,super.disposed()}}class Mg extends T.O8{constructor(){super(),this.managedLayers=new Array,this.layerSet=new Set,this.layersChanged=new j.IY,this.readyStateChanged=new j.IY,this.specificationChanged=new j.IY,this.boundPositions=new WeakSet,this.numDirectUsers=0,this.nonArchivedLayerIndexGeneration=-1,this.renderLayerToManagedLayerMapGeneration=-1,this.renderLayerToManagedLayerMap_=new Map,this.scheduleRemoveLayersWithSingleRef=this.registerCancellable((0,Fe.A)(()=>this.removeLayersWithSingleRef(),0)),this.layersChanged.add(this.scheduleRemoveLayersWithSingleRef)}updateNonArchivedLayerIndices(){const e=this.layersChanged.count;if(e===this.nonArchivedLayerIndexGeneration)return;this.nonArchivedLayerIndexGeneration=e;let t=0;for(const n of this.managedLayers)n.archived||(n.nonArchivedLayerIndex=t++);for(const n of this.managedLayers)n.archived&&(n.nonArchivedLayerIndex=t++)}getLayerByNonArchivedIndex(e){let t=0;for(const n of this.managedLayers)if(!n.archived){if(t===e)return n;++t}}get renderLayerToManagedLayerMap(){const e=this.layersChanged.count,t=this.renderLayerToManagedLayerMap_;if(this.renderLayerToManagedLayerMapGeneration!==e){this.renderLayerToManagedLayerMapGeneration=e,t.clear();for(const n of this.managedLayers){const s=n.layer;if(s!==null)for(const r of s.renderLayers)t.set(r,n)}}return t}filter(e){let t=!1;this.managedLayers=this.managedLayers.filter(n=>e(n)?!0:(this.unbindManagedLayer(n),this.layerSet.delete(n),t=!0,!1)),t&&this.layersChanged.dispatch()}removeLayersWithSingleRef(){this.numDirectUsers>0||this.filter(e=>e.refCount!==1||e.archived)}updateSignalBindings(e,t){t(e.layerChanged,this.layersChanged.dispatch),t(e.readyStateChanged,this.readyStateChanged.dispatch),t(e.specificationChanged,this.specificationChanged.dispatch)}useDirectly(){return++this.numDirectUsers===1&&this.layersChanged.remove(this.scheduleRemoveLayersWithSingleRef),()=>{--this.numDirectUsers===0&&(this.layersChanged.add(this.scheduleRemoveLayersWithSingleRef),this.scheduleRemoveLayersWithSingleRef())}}addManagedLayer(e,t){return this.updateSignalBindings(e,PT),this.layerSet.add(e),e.containers.add(this),t===void 0&&(t=this.managedLayers.length),this.managedLayers.splice(t,0,e),this.layersChanged.dispatch(),this.readyStateChanged.dispatch(),e}*readyRenderLayers(){for(const e of this.managedLayers)!e.visible||!e.layer||(yield*e.layer.renderLayers)}unbindManagedLayer(e){this.updateSignalBindings(e,kT),e.containers.delete(this),e.manager.rootLayers.layersChanged.dispatch(),e.dispose()}clear(){for(const e of this.managedLayers)this.unbindManagedLayer(e);this.managedLayers.length=0,this.layerSet.clear(),this.layersChanged.dispatch()}remove(e){const t=this.managedLayers[e];this.unbindManagedLayer(t),this.managedLayers.splice(e,1),this.layerSet.delete(t),this.layersChanged.dispatch()}removeManagedLayer(e){const t=this.managedLayers.indexOf(e);if(t===-1)throw new Error("Internal error: invalid managed layer.");this.remove(t)}reorderManagedLayer(e,t){const n=this.managedLayers.length;if(e===t||e<0||e>=n||t<0||t>=n)return;const[s]=this.managedLayers.splice(e,1);this.managedLayers.splice(t,0,s),this.layersChanged.dispatch()}disposed(){this.clear(),super.disposed()}getLayerByName(e){return this.managedLayers.find(t=>t.name===e)}getUniqueLayerName(e){let t=e,n=0;for(;this.getLayerByName(t)!==void 0;)t=e+ ++n;return t}has(e){return this.layerSet.has(e)}get renderLayers(){const e=this;return{*[Symbol.iterator](){for(const t of e.managedLayers)if(t.layer!==null)for(const n of t.layer.renderLayers)yield n}}}get visibleRenderLayers(){const e=this;return{*[Symbol.iterator](){for(const t of e.managedLayers)if(!(t.layer===null||!t.visible))for(const n of t.layer.renderLayers)yield n}}}invokeAction(e){const t=new MT;for(const n of this.managedLayers){if(n.layer===null||!n.visible)continue;const s=n.layer;s.handleAction(e,t);for(const r of s.renderLayers)r.handleAction(e)}for(const n of t.callbacks)n()}}class OT{constructor(){this.changed=new j.IY,this.coordinateSpace=Fn,this.position=ps,this.unsnappedPosition=ps,this.active=!1,this.displayDimensions=void 0,this.pickedRenderLayer=null,this.pickedValue=new P.R(0,0),this.pickedOffset=0,this.pickedAnnotationLayer=void 0,this.pickedAnnotationId=void 0,this.pickedAnnotationBuffer=void 0,this.pickedAnnotationBufferBaseOffset=void 0,this.pickedAnnotationIndex=void 0,this.pickedAnnotationCount=void 0,this.pickedAnnotationType=void 0,this.forcerFunction=void 0}removeForcer(e){e===this.forcerFunction&&(this.forcerFunction=void 0,this.setActive(!1))}setForcer(e){this.forcerFunction=e,e===void 0&&this.setActive(!1)}updateUnconditionally(){const{forcerFunction:e}=this;return e===void 0?!1:(e(),this.active)}setActive(e){(this.active!==e||e===!0)&&(this.active=e,this.changed.dispatch())}}class _T extends T.O8{constructor(e,t){super(),this.layerManager=e,this.mouseState=t,this.changed=new j.IY,this.needsUpdate=!0,this.registerDisposer(t.changed.add(()=>{this.handleChange()})),this.registerDisposer(e.layersChanged.add(()=>{this.handleLayerChange()}))}handleLayerChange(){this.mouseState.active&&this.handleChange()}handleChange(){this.needsUpdate=!0,this.changed.dispatch()}update(){if(!this.needsUpdate)return;this.needsUpdate=!1;const e=this.mouseState,t=this.changed.count;if(e.active)for(const n of this.layerManager.managedLayers){const s=n.layer;if(n.visible&&s!==null){const{selectionState:r}=s;s.resetSelectionState(r),r.generation=t,s.captureSelectionState(r,e)}}}get(e){this.update();const{selectionState:t}=e;if(t.generation===this.changed.count)return t}toJSON(){this.update();const e={};for(const t of this.layerManager.managedLayers){const n=t.layer;if(n){const s=this.get(n);s!==void 0&&(e[t.name]=n.selectionStateToJson(s,!0))}}return e}}const Ng=10,qc={...Ui,minSize:150,row:1},Og={...qc,visible:!0};class VT extends T.O8{constructor(e,t){super(),this.coordinateSpace=e,this.layerSelectedValues=t,this.changed=new j.IY,this.history=[],this.historyIndex=0,this.location=new Si(qc),this.pin=new _.B0(!0),this.registerDisposer((0,_.no)((n,s)=>{s||(this.capture(!0),n.registerDisposer(t.changed.add(n.registerCancellable((0,la.A)(()=>this.capture(!0),100,{leading:!0,trailing:!0})))))},this.pin)),this.pin.changed.add(this.changed.dispatch),this.location.changed.add(this.changed.dispatch)}get value(){return this.value_}goBack(){const e=this.pin.value?this.historyIndex:this.history.length;e>0&&(this.historyIndex=e-1,this.value_=this.history[e-1],this.pin.value=!0,this.changed.dispatch())}canGoBack(){return(this.pin.value?this.historyIndex:this.history.length)>0}canGoForward(){return this.pin.value?this.historyIndex+1Ng&&t.splice(0,t.length-Ng),this.historyIndex=t.length-1}this.changed.dispatch()}}captureSingleLayerState(e,t,n=!0){if(n===!1&&(!this.location.visible||this.pin.value))return;const s={};e.initializeSelectionState(s),t(s)&&(this.location.visible=!0,n===!0?this.pin.value=!0:n==="toggle"&&(this.pin.value=!this.pin.value),this.value={layers:[{layer:e,state:s}],coordinateSpace:this.coordinateSpace.value,position:void 0})}reset(){this.location.reset(),this.pin.value=!1,this.value=void 0}toJSON(){const{value:e}=this;let t;if(this.location.visible){if(t=this.location.toJSON(Og),this.pin.value&&e!==void 0){const n={};for(const s of e.layers){const{layer:r}=s;let o=r.selectionStateToJson(s.state,!1);Object.keys(o).length===0&&(o=void 0),n[s.layer.managedLayer.name]=o}e.position!==void 0&&(t.position=Array.from(e.position)),t.layers=n}}else t=this.location.toJSON(qc),t=(0,f.Zu)(t),t!==void 0&&(t.visible=!1);return t}select(){const{pin:e}=this;this.location.visible=!0,e.value=!e.value,e.value&&this.capture()}capture(e=!1){const t=BT(this.layerSelectedValues);e&&t===void 0||(this.value=t)}restoreState(e){if(e===void 0){this.pin.value=!0,this.value=void 0;return}if(e===null){this.pin.value=!1,this.location.visible=!0,this.value=void 0;return}(0,f.Rf)(e),this.location.restoreState(e,Og);const t=this.coordinateSpace.value,n=(0,f.MM)(e,"position",r=>(0,f.Xu)(new Float32Array(t.rank),r,f.zo)),s=[];(0,f.MM)(e,"layers",r=>{(0,f.Rf)(r);const{layerManager:o}=this.layerSelectedValues;for(const[a,l]of Object.entries(r)){const c=o.getLayerByName(a);if(c===void 0)return;const d=c.layer;if(d===null)return;(0,f.Rf)(l);const u={};d.initializeSelectionState(u),d.selectionStateFromJson(u,l),s.push({layer:d,state:u})}}),this.pin.value=s.length>0||n!==void 0,this.value={position:n,coordinateSpace:t,layers:s}}}function BT(i){const{mouseState:e}=i;if(!e.active)return;const t=[];for(const n of i.layerManager.managedLayers){const s=n.layer;if(s===null)continue;const r=i.get(s);if(r===void 0)continue;const o={};s.initializeSelectionState(o),s.copySelectionState(o,r),t.push({layer:s,state:o})}return{position:e.position.slice(),coordinateSpace:e.coordinateSpace,layers:t}}class FT extends T.O8{constructor(e){super(),this.view=e,this.messages=new ai,this.seenGeneration=-1,this.state=void 0}}let UT=0;class $T extends T.O8{constructor(e,t,n,s,r,o){super(),this.layerManager=e,this.renderLayerType=t,this.view=n,this.roles=s,this.layerAdded=r,this.visibility=o,this.visibleLayers_=new Map,this.debouncedUpdateVisibleLayers=this.registerCancellable((0,Fe.A)(()=>this.updateVisibleLayers(),0)),this.registerDisposer(e.layersChanged.add(this.debouncedUpdateVisibleLayers)),this.registerDisposer(s.changed.add(this.debouncedUpdateVisibleLayers)),this.updateVisibleLayers()}disposed(){this.visibleLayers.forEach(e=>e.dispose()),this.visibleLayers.clear(),super.disposed()}updateVisibleLayers(){const e=++UT,{visibleLayers_:t,renderLayerType:n,layerAdded:s,roles:r}=this;for(const o of this.layerManager.readyRenderLayers())if(o instanceof n&&r.has(o.role)){const a=o;let l=t.get(a);l===void 0&&(l=new FT(this.view),l.registerDisposer(a.messages.addChild(l.messages)),l.registerDisposer(a.addRef()),l.registerDisposer(a.visibility.add(this.visibility)),t.set(a,l),s(a,l),a.attach(l)),l.seenGeneration=e}for(const[o,a]of t)a.seenGeneration!==e&&(t.delete(o),a.dispose())}get visibleLayers(){return this.debouncedUpdateVisibleLayers.flush(),this.visibleLayers_}}function _g(i,e,t,n,s){return n.registerDisposer(new $T(i,e,n,t,(r,o)=>{o.registerDisposer(r.redrawNeeded.add(()=>n.scheduleRedraw()));const{backend:a}=r;a&&(a.rpc.invoke(go.sC,{layer:a.rpcId,view:n.rpcId}),o.registerDisposer(()=>a.rpc.invoke(go.lG,{layer:a.rpcId,view:n.rpcId}))),s!==void 0&&s(r,o),n.scheduleRedraw(),o.registerDisposer(()=>n.scheduleRedraw())},n.visibility))}class GT extends T.O8{constructor(e){super(),this.layerManager=e,this.changed=new j.IY,this.location=new Si(LT),this.registerDisposer(e),this.location.changed.add(()=>{this.changed.dispatch();const t=this.layer?.layer??void 0;if(t!==void 0){const n=this.location.value;if(n.visible){const s=t.panels.panels[0];s.location.value!==n&&(s.location.value=n,s.location.locationChanged.dispatch())}}})}get layer(){return this.layer_}get visible(){return this.location.visible}toggle(e){this.layer===e&&this.visible?this.visible=!1:(this.layer=e,this.visible=!0)}set visible(e){let t=this.layer_;if(e===!0&&t===void 0){const{managedLayers:n}=this.layerManager;n.length>0?t=this.layer=n[0]:e=!1}if(e===!0&&t!==void 0){const n=t.layer;(n===null||n.panels.panels[0].tabs.length===0)&&(e=!1)}this.visible!==e&&(this.location.visible=e,!e&&t!==void 0&&this.maybeDeleteNewLayer(t),this.changed.dispatch())}maybeDeleteNewLayer(e){if(e.wasDisposed)return;const t=e.layer;t!==null&&t instanceof jn&&(t.dataSources.some(n=>n.spec.url.length!==0)||Ms(e))}set layer(e){if(e===this.layer_)return;const t=this.layer_;if(t!==void 0&&(this.existingLayerDisposer(),this.existingLayerDisposer=void 0,this.maybeDeleteNewLayer(t)),this.layer_=e,e!==void 0){const n=()=>{this.layer_=void 0,this.visible=!1,this.existingLayerDisposer=void 0,this.changed.dispatch()};e.registerDisposer(n);const s=e.specificationChanged.add(()=>{this.changed.dispatch()});this.existingLayerDisposer=()=>{const r=e.layer;if(r!==null){const o=r.tool.value;o!==void 0&&o.deactivate()}e.unregisterDisposer(n),s()}}else this.location.visible=!1;this.changed.dispatch()}toJSON(){const e=this.location.toJSON();return this.layer!==void 0&&(e.layer=this.layer.name),(0,f.Zu)(e)}restoreState(e){if(e===void 0){this.reset();return}(0,f.Rf)(e),this.location.restoreState(e);const t=(0,f.cQ)(e,"layer",f.z$),n=t!==void 0?this.layerManager.getLayerByName(t):void 0;n===void 0&&(this.visible=!1),this.layer=n}reset(){this.location.reset(),this.layer=void 0}}class zT extends T.O8{constructor(e,t){super(),this.layerManager=e,this.filter=t,this.changed=new j.IY,this.validate=(0,Fe.A)(()=>{const{layerName_:n}=this;if(n!==void 0){const s=this.layerManager.getLayerByName(n);s!==void 0&&this.filter(s)?(this.layer_=s,this.changed.dispatch()):(this.layer_=void 0,this.layerName_=void 0,this.changed.dispatch())}},0),this.registerDisposer(e),this.registerDisposer(e.specificationChanged.add(()=>{const{layer_:n}=this;if(n!==void 0)if(!this.layerManager.layerSet.has(n)||!this.filter(n))this.layer_=void 0,this.layerName_=void 0,this.changed.dispatch();else{const{name:s}=n;s!==this.layerName_&&(this.layerName_=s,this.changed.dispatch())}}))}get layer(){return this.layer_}get layerName(){return this.layerName_}set layer(e){this.layer_!==e&&(e!==void 0&&this.layerManager.layerSet.has(e)&&this.filter(e)?(this.layer_=e,this.layerName_=e.name):(this.layer_=void 0,this.layerName_=void 0),this.changed.dispatch())}set layerName(e){e!==this.layerName_&&(this.layer_=void 0,this.layerName_=e,this.changed.dispatch(),this.validate())}restoreState(e){const t=(0,f.z$)(e);this.layerName=t}toJSON(){const{layer_:e}=this;return e!==void 0?e.name:this.layerName_}reset(){this.layerName_=void 0,this.layer_=void 0,this.changed.dispatch()}}class Vg extends T.O8{constructor(e,t,n,s){super(),this.layerManager=e,this.layer=t,this.predicate=n,this.getGroup=s,this.linkedLayers_=new Set,this.changed=new j.IY,this.linkedLayersChanged=new j.IY,this.root_=t;const r=this;this.root={get value(){return r.root_},changed:r.changed}}get linkedLayers(){return this.linkedLayers_}get rootGroup(){return this.getGroup(this.root.value)}reset(){this.isolate()}restoreState(e){if(e===void 0)return;const t=(0,f.zr)(e);this.linkByName(t)}toJSON(){const{root:{value:e}}=this;if(e!==this.layer)return e.managedLayer.name}isolate(e=!0){const{getGroup:t,layer:n,root_:s}=this;if(s===n){const{linkedLayers_:o}=this;if(o.size!==0){for(const a of o){const l=t(a);l.root_=a,l.changed.dispatch()}o.clear(),this.linkedLayersChanged.dispatch()}return}const r=t(s);r.linkedLayers_.delete(n),r.linkedLayersChanged.dispatch(),this.root_=n,e&&this.changed.dispatch()}linkByName(e){const{layer:t}=this,{managedLayer:n}=t,{layerManager:s}=this,r=s.getLayerByName(e);if(r===void 0||r===n)return;const o=r.layer;o!==null&&this.predicate(o)&&this.linkToLayer(o)}linkToLayer(e){if(e===this.layer||this.root_===e)return;this.root_!==this.layer&&this.isolate(!1);const{getGroup:t}=this,n=t(e).root_;if(n===this.layer)return;const s=t(n);s.linkedLayers_.add(this.layer),s.linkedLayersChanged.dispatch(),this.root_=n,this.changed.dispatch()}disposed(){this.isolate(!1)}}function Bg(i,e){const t=(0,f.MM)(e,"type",f.zr,"auto");i.archived=(0,f.MM)(e,"archived",f.aO,!1),i.archived?i.visible=!1:i.visible=(0,f.MM)(e,"visible",f.aO,!0);const n=Mr.get(t)||jn;return i.layer=new n(i),e}function Fg(i,e){try{const t=i.layer;if(t===null)return;t.restoreState(e),t.initializationDone()}catch(t){throw Ms(i),t}}function Ug(i,e){try{(0,f.Rf)(e),Bg(i,e),Fg(i,e)}catch(t){throw Ms(i),t}}function WT(i,e){try{Ug(i,e)}catch(t){new pe().setErrorMessage(t instanceof Error?t.message:""+t)}}function $g(i,e,t){const n=new Kc(e,i);return Ug(n,t),n}class Gg extends T.O8{constructor(){super(...arguments),this.changed=new j.IY}}class HT extends Gg{constructor(e,t,n,s,r,o,a,l,c){super(),this.display=e,this.dataSourceProviderRegistry=t,this.layerManager=n,this.chunkManager=s,this.selectionState=r,this.selectedLayer=o,this.coordinateSpace=a,this.globalPosition=l,this.toolBinder=c,this.coordinateSpaceCombiner=new Ql(this.coordinateSpace,DC),this.subsets=new Set,this.layerSelectedValues=this.selectionState.layerSelectedValues,this.registerDisposer(n.layersChanged.add(this.changed.dispatch)),this.registerDisposer(n.specificationChanged.add(this.changed.dispatch))}get rpc(){return this.chunkManager.rpc}get root(){return this}reset(){this.layerManager.clear()}restoreState(e){this.layerManager.clear();let t;Array.isArray(e)?t=e:((0,f.Rf)(e),t=Object.entries(e).map(([s,r])=>typeof r=="string"?{name:s,source:r}:((0,f.Rf)(r),{...r,name:s})));const n=[];for(const s of t){(0,f.Rf)(s);const r=this.layerManager.getUniqueLayerName((0,f.cQ)(s,"name",f.zr)),o=new Kc(r,this);try{Bg(o,s),this.layerManager.addManagedLayer(o),n.push({managedLayer:o,spec:s})}catch(a){o.dispose(),new pe().setErrorMessage(`Error creating layer ${JSON.stringify(r)}: `+(a instanceof Error)?a.message:""+a)}}for(const{managedLayer:s,spec:r}of n)try{Fg(s,r)}catch(o){new pe().setErrorMessage(`Error creating layer ${JSON.stringify(name)}: `+(o instanceof Error)?o.message:""+o)}}add(e,t){this.layerManager.managedLayers.indexOf(e)===-1&&(e.name=this.layerManager.getUniqueLayerName(e.name)),this.layerManager.addManagedLayer(e,t)}toJSON(){const e=[];let t=0;for(const n of this.layerManager.managedLayers){const s=n.toJSON();s!=null&&(e.push(s),++t)}if(t!==0)return e}get rootLayers(){return this.layerManager}}class zg extends Gg{constructor(e){super(),this.master=e,this.changed=new j.IY,this.layerManager=this.registerDisposer(new Mg),this.registerDisposer(e);const{layerManager:t}=this;this.registerDisposer(t.layersChanged.add(this.changed.dispatch)),this.registerDisposer(t.specificationChanged.add(this.changed.dispatch)),e.subsets.add(this)}get rpc(){return this.master.rpc}get dataSourceProviderRegistry(){return this.master.dataSourceProviderRegistry}get chunkManager(){return this.master.chunkManager}get layerSelectedValues(){return this.master.layerSelectedValues}get root(){return this.master}disposed(){super.disposed(),this.master.subsets.delete(this)}reset(){this.layerManager.clear()}restoreState(e){const t=this.master.layerManager,n=[];for(const s of new Set((0,f.$v)(e,f.zr))){const r=t.getLayerByName(s);if(r===void 0)throw new Error(`Undefined layer referenced in subset specification: ${JSON.stringify(s)}`);r.archived||n.push(r)}this.layerManager.clear();for(const s of n)this.layerManager.addManagedLayer(s.addRef())}toJSON(){return this.layerManager.managedLayers.map(e=>e.name)}add(e,t){this.master.layerManager.managedLayers.indexOf(e)===-1&&(e.name=this.master.layerManager.getUniqueLayerName(e.name),this.master.layerManager.addManagedLayer(e.addRef())),this.layerManager.addManagedLayer(e,t)}get rootLayers(){return this.master.rootLayers}}const Mr=new Map,Xc=new Map,Wg=[i=>{const{volume:e}=i;if(e===void 0)return;const t=Xc.get(e.volumeType);if(t!==void 0)return{layerConstructor:t,priority:0}}];function $i(i,e=i.type){Mr.set(e,i)}function da(i){Wg.push(i)}function Hg(i,e){Xc.set(i,e)}function Zc(i,e){const t=i.layer;if(t===null)return;const n=t.toJSON(),s=new e(i);s.restoreState(n),s.initializationDone(),i.layer=s}function Jg(i,e){return e!==i.name?(e=i.manager.root.layerManager.getUniqueLayerName(e),i.name=e,i.layerChanged.dispatch(),!0):!1}function Ms(i){if(!i.wasDisposed)for(const e of i.containers)e.removeManagedLayer(i)}function ua(i,e){return i===void 0?e:e===void 0?i:i.priority{r&&o.appendChild(sm(a,e,n,t))},t)).element}function gd(i,e){const{toolJson:t}=e,n=typeof t=="string"?t:t.type;sn(i,n,s=>new im(s,e))}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Nr(i){return{makeControl:(e,t)=>{const n=i(e),s=t.registerDisposer(new pn(n));return{control:s,controlElement:s.element}},activateTool:(e,t)=>{t.model.value=!t.model.value}}}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const QT=Ae.fromObject({"at:shift+wheel":{action:"adjust-via-wheel"}});function md(i){return{makeControl:(e,t)=>{const n=i(e),s=t.registerDisposer(new Bo(n));return{control:s,controlElement:s.element}},activateTool:(e,t)=>{e.bindInputEventMap(QT),e.bindAction("adjust-via-wheel",n=>{n.stopPropagation(),n.preventDefault(),t.adjustViaWheel(n.detail)})}}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class KT extends T.O8{constructor(e,{min:t=0,max:n=1,step:s=.01}={}){super(),this.value=e,this.element=document.createElement("label"),this.inputElement=document.createElement("input"),this.numericInputElement=document.createElement("input");const{element:r,inputElement:o,numericInputElement:a}=this;r.className="range-slider";const l=d=>{d.min=""+t,d.max=""+n,d.step=""+s,d.valueAsNumber=this.value.value,this.registerEventListener(d,"change",()=>this.inputValueChanged(d)),this.registerEventListener(d,"input",()=>this.inputValueChanged(d)),this.registerEventListener(d,"wheel",u=>{this.adjustViaWheel(d,u)})};o.type="range",l(o),a.type="number";const c=Math.max(t.toString().length,n.toString().length,Math.min(n,t+s).toString().length,Math.max(t,n-s).toString().length);a.style.width=c+2+"ch",l(a),r.appendChild(o),r.appendChild(a),e.changed.add(()=>{this.inputElement.valueAsNumber=this.value.value,this.numericInputElement.valueAsNumber=this.value.value})}inputValueChanged(e){this.value.value=e.valueAsNumber}adjustViaWheel(e,t){const n=this.inputElement,{deltaY:s}=t;s>0?(n.stepUp(),this.inputValueChanged(e)):s<0&&(n.stepDown(),this.inputValueChanged(e))}disposed(){at(this.element),super.disposed()}}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const qT=Ae.fromObject({"at:shift+wheel":{action:"adjust-via-wheel"}});function Yn(i){return{makeControl:(e,t)=>{const{value:n,options:s}=i(e),r=t.registerDisposer(new KT(n,s));return{control:r,controlElement:r.element}},activateTool:(e,t)=>{e.bindInputEventMap(qT),e.bindAction("adjust-via-wheel",n=>{n.stopPropagation(),n.preventDefault(),t.adjustViaWheel(t.inputElement,n.detail)})}}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function rm(i,e){let t="";for(let n=0;n<=e&&(t=i.toFixed(n),parseFloat(t)!==i);++n);return t}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const XT=200,om=Ae.fromObject({mousedown0:{action:"set"},wheel:{action:"adjust-via-wheel"},dblclick0:{action:"reset"}});function ZT(i){if(i<1||i>1024){const e=Math.log2(i)|0,t=i/2**e;return`${rm(t,1)}p${e}`}return Math.round(i)+""}class ga extends T.O8{constructor(e,t){super(),this.histogram=e,this.target=t,this.label=document.createElement("div"),this.element=document.createElement("div"),this.canvas=document.createElement("canvas"),this.legend=document.createElement("div"),this.legendRenderScale=document.createElement("div"),this.legendSpatialScale=document.createElement("div"),this.legendChunks=document.createElement("div"),this.logScaleOrigin=ks,this.unitOfTarget="px",this.ctx=this.canvas.getContext("2d"),this.hoverTarget=new _.B0(void 0),this.throttledUpdateView=this.registerCancellable((0,la.A)(()=>this.debouncedUpdateView(),XT,{leading:!0,trailing:!0})),this.debouncedUpdateView=this.registerCancellable((0,Fe.A)(()=>this.updateView(),0));const{canvas:n,label:s,element:r,legend:o,legendRenderScale:a,legendSpatialScale:l,legendChunks:c}=this;s.className="neuroglancer-render-scale-widget-prompt",r.className="neuroglancer-render-scale-widget",r.title=om.describe(),o.className="neuroglancer-render-scale-widget-legend",r.appendChild(s),r.appendChild(n),r.appendChild(o),a.title="Target resolution of data in screen pixels",c.title="Number of chunks rendered",o.appendChild(a),o.appendChild(c),o.appendChild(l),this.registerDisposer(e.changed.add(this.throttledUpdateView)),this.registerDisposer(e.visibility.changed.add(this.debouncedUpdateView)),this.registerDisposer(t.changed.add(this.debouncedUpdateView)),this.registerDisposer(new tn(n,om)),this.registerDisposer(t.changed.add(this.debouncedUpdateView)),this.registerDisposer(this.hoverTarget.changed.add(this.debouncedUpdateView));const d=h=>{const p=h.offsetX/n.width*mt;return aT(p,this.logScaleOrigin)};this.registerEventListener(n,"pointermove",h=>{this.hoverTarget.value=[d(h),h.offsetY]}),this.registerEventListener(n,"pointerleave",()=>{this.hoverTarget.value=void 0}),this.registerDisposer(Z(n,"set",h=>{this.target.value=d(h.detail)})),this.registerDisposer(Z(n,"adjust-via-wheel",h=>{this.adjustViaWheel(h.detail)})),this.registerDisposer(Z(n,"reset",h=>{this.reset(),h.preventDefault()}));const u=new ResizeObserver(()=>this.debouncedUpdateView());u.observe(n),this.registerDisposer(()=>u.disconnect()),this.updateView()}adjustViaWheel(e){const t=this.getWheelMoveValue(e);if(t===0)return;this.hoverTarget.value=void 0;const n=Math.round(this.logScaleOrigin+mt*Ir),s=Pe([2**this.logScaleOrigin,2**(n-1)],this.target.value*2**Math.sign(t));this.target.value=s,e.preventDefault()}getWheelMoveValue(e){return e.deltaY}reset(){this.hoverTarget.value=void 0,this.target.reset()}updateView(){const{ctx:e}=this,{canvas:t}=this,n=t.width=t.offsetWidth,s=t.height=t.offsetHeight,r=this.target.value,o=this.hoverTarget.value;{const{legendRenderScale:E}=this,D=o===void 0?r:o[0],I=ZT(D);E.textContent=I+" "+this.unitOfTarget}function a(E){return E*n/mt}e.clearRect(0,0,n,s);const{histogram:l}=this,{value:c,spatialScales:d}=l;l.visibility.visible||c.fill(0);const u=Array.from(d.keys());u.sort();const h=C.eR.create();let p=1;const m=d.size;let g=0,v=0;for(let E=0;E=0&&E=0;--L){const N=u[L],O=2*d.get(N)*mt+E,V=c[O]+c[O+mt];if(V===0)continue;const z=Math.round(w(D));if(D+=V,Math.round(w(D))<=I&&I<=z){b=N;break}}}}if(b!==void 0){g=0,v=0;const D=2*d.get(b)*mt;for(let I=0;I{const D=E===b?.5:1;let I;Number.isFinite(E)?I=(Math.log2(E)*.1%1+1)%1:I=0,Mo(h,I,D,1);const L=Ge(h);Mo(h,I,D,.5);const N=Ge(h);return[L,N]});for(let E=0;E=0;--I){const L=u[I],k=d.get(L)*mt*2+E,O=c[k],V=c[k+mt],z=O+V;if(z===0)continue;const Y=Math.round(a(E)),Q=Math.round(a(E+1)),X=Math.round(w(D));D+=z;const ce=Math.round(w(D)),oe=(O*ce+V*X)/z;e.fillStyle=x[I][1],e.fillRect(Y,ce,Q-Y,oe-ce),e.fillStyle=x[I][0],e.fillRect(Y,oe,Q-Y,X-oe)}}{const E=r;e.fillStyle="#fff";const D=a(ea(E,this.logScaleOrigin));e.fillRect(Math.floor(D),0,1,s)}if(o!==void 0){const E=o[0];e.fillStyle="#888";const D=a(ea(E,this.logScaleOrigin));e.fillRect(Math.floor(D),0,1,s)}}}class eD extends ga{constructor(){super(...arguments),this.unitOfTarget="samples",this.logScaleOrigin=1}getWheelMoveValue(e){return-e.deltaY}}const tD=Ae.fromObject({"at:shift+wheel":{action:"adjust-via-wheel"},"at:shift+dblclick0":{action:"reset"}});function ma(i,e=ga){return{makeControl:(t,n)=>{const{histogram:s,target:r}=i(t),o=n.registerDisposer(new e(s,r));return{control:o,controlElement:o.element}},activateTool:(t,n)=>{t.bindInputEventMap(tD),t.bindAction("adjust-via-wheel",s=>{s.stopPropagation(),s.preventDefault(),n.adjustViaWheel(s.detail)}),t.bindAction("reset",s=>{s.stopPropagation(),s.preventDefault(),n.reset()})}}}var nD=G(8682);/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const iD=Ae.fromObject({"at:shift+wheel":{action:"adjust-hue-via-wheel"}});function am(i){return{makeControl:(e,t)=>{const n=i(e),s=t.registerDisposer(new hi(n));return{control:s,controlElement:s.element}},activateTool:(e,t)=>{e.bindInputEventMap(iD),e.bindAction("adjust-via-wheel",n=>{n.stopPropagation(),n.preventDefault(),t.adjustHueViaWheel(n.detail)})}}}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class lm extends T.O8{constructor(e){super(),this.model=e,this.element=document.createElement("input"),this.registerDisposer(e.changed.add(()=>this.updateView()));const{element:t}=this;t.type="text",this.registerEventListener(t,"change",()=>this.updateModel()),this.updateView()}disposed(){at(this.element)}updateView(){this.element.value=(this.model.value??"")+""}updateModel(){try{this.model.restoreState(this.element.value)}catch{}this.updateView()}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function va(i,e){e?i.displayState.segmentDefaultColor.value=C.eR.fromValues(1,0,0):i.displayState.segmentDefaultColor.value=void 0}function sD(){const i=e=>{e.displayState.segmentationColorGroupState.value.segmentColorHash.randomize()};return{makeControl:(e,t,{labelTextContainer:n})=>{const s=document.createElement("input");s.type="radio",s.addEventListener("change",()=>{va(e,!s.checked)}),n.prepend(s);const r=document.createElement("div");r.classList.add("neuroglancer-segmentation-color-seed-control");const o=t.registerDisposer(new lm(e.displayState.segmentColorHash));r.appendChild(o.element);const a=Ne({svg:nD,title:"Randomize",onClick:()=>i(e)});return r.appendChild(a),t.registerDisposer((0,_.W1)(l=>{const c=l===void 0;r.style.visibility=c?"":"hidden",s.checked=c},e.displayState.segmentDefaultColor)),{controlElement:r,control:o}},activateTool:e=>{const{layer:t}=e.tool;va(t,!1),i(t)}}}function rD(){const i=am(e=>e.displayState.segmentDefaultColor);return{...i,makeControl:(e,t,n)=>{const s=i.makeControl(e,t,n),{controlElement:r}=s,o=document.createElement("input");return o.type="radio",o.addEventListener("change",()=>{va(e,o.checked),o.checked&&r.click()}),n.labelTextContainer.prepend(o),t.registerDisposer((0,_.W1)(a=>{const l=a!==void 0;r.style.visibility=l?"":"hidden",o.checked=l},e.displayState.segmentDefaultColor)),s},activateTool:(e,t)=>{va(e.tool.layer,!0),i.activateTool(e,t)}}}const cm=[{label:"Color seed",title:"Color segments based on a hash of their id",toolJson:dd,...sD()},{label:"Fixed color",title:"Use a fixed color for all segments without an explicitly-specified color",toolJson:fd,...rD()},{label:"Saturation",toolJson:sd,title:"Saturation of segment colors",...Yn(i=>({value:i.displayState.saturation}))},{label:"Opacity (on)",toolJson:td,isValid:i=>i.has2dLayer,title:"Opacity in cross-section views of segments that are selected",...Yn(i=>({value:i.displayState.selectedAlpha}))},{label:"Opacity (off)",toolJson:nd,isValid:i=>i.has2dLayer,title:"Opacity in cross-section views of segments that are not selected",...Yn(i=>({value:i.displayState.notSelectedAlpha}))},{label:"Resolution (slice)",toolJson:hd,isValid:i=>i.has2dLayer,...ma(i=>({histogram:i.sliceViewRenderScaleHistogram,target:i.sliceViewRenderScaleTarget}))},{label:"Resolution (mesh)",toolJson:ud,isValid:i=>i.has3dLayer,...ma(i=>({histogram:i.displayState.renderScaleHistogram,target:i.displayState.renderScaleTarget}))},{label:"Opacity (3d)",toolJson:id,isValid:i=>i.has3dLayer,title:"Opacity of meshes and skeletons",...Yn(i=>({value:i.displayState.objectAlpha}))},{label:"Silhouette (3d)",toolJson:pd,isValid:i=>i.has3dLayer,title:"Set to a non-zero value to increase transparency of object faces perpendicular to view direction",...Yn(i=>({value:i.displayState.silhouetteRendering,options:{min:0,max:oD,step:.1}}))},{label:"Hide segment ID 0",toolJson:od,title:"Disallow selection and display of segment id 0",...Nr(i=>i.displayState.hideSegmentZero)},{label:"Base segment coloring",toolJson:ad,title:"Color base segments individually",...Nr(i=>i.displayState.baseSegmentColoring)},{label:"Show all by default",title:"Show all segments if none are selected",toolJson:ld,...Nr(i=>i.displayState.ignoreNullVisibleSet)},{label:"Highlight on hover",toolJson:rd,title:"Highlight the segment under the mouse pointer",...Nr(i=>i.displayState.hoverHighlight)},...dm("2d"),...dm("3d")],oD=10;function dm(i){return[{label:`Skeleton mode (${i})`,toolJson:`${pa}.mode${i}`,isValid:e=>e.hasSkeletonsLayer,...md(e=>e.displayState.skeletonRenderingOptions[`params${i}`].mode)},{label:`Line width (${i})`,toolJson:`${pa}.lineWidth${i}`,isValid:e=>e.hasSkeletonsLayer,toolDescription:`Skeleton line width (${i})`,title:`Skeleton line width (${i})`,...Yn(e=>({value:e.displayState.skeletonRenderingOptions[`params${i}`].lineWidth,options:{min:1,max:40,step:1}}))}]}function aD(i){for(const e of cm)gd(i,e)}var bn=G(3708);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function lD(i,e,t){return i&1|e<<1&2|t<<2&4}function jV(i,e,t,n){const s=Math.max(e,t,n);let r=0,o=i.low,a=0,l=0,c=0;for(let d=0;d>>r&1;a|=u<>>r&1;l|=u<>>r&1;c|=u<>>0,c=0,l=0,d=!0)}for(let h=0;h>h&1),h>h&1),h>h&1);return d?i.high=c>>>0:(i.high=0,i.low=c>>>0),i}function QV(i,e,t){let n=0;const s=e.length;let r=0,o=!1;function a(l){r|=(l&1)<>>0,r=0,n=0,o=!0)}for(let l=0;l<32;++l)for(let c=0;c>>l&&a(e[c]>>>l);return o?i.high=r>>>0:(i.high=0,i.low=r>>>0),i}function um(i,e){return i0?0:1,D=w>0?0:1,I=b>0?0:1,L=t[4*4],N=t[4*4+1],k=t[4*4+2],O=t[4*4+3];function V(dt,be,Ye){return S*dt+w*be+b*Ye+x}function z(dt,be,Ye,bt,ni,oo){return V(dt+E*(bt-dt),be+D*(ni-be),Ye+I*(oo-Ye))}const Y=V(-O*L,-O*N,-O*k),Q=i.clipLowerBound[0],X=i.clipLowerBound[1],ce=i.clipLowerBound[2],oe=i.clipUpperBound[0],Se=i.clipUpperBound[1],Ke=i.clipUpperBound[2],$e=Math.sqrt((h*s)**2+(g*r)**2),Tt=Math.sqrt((p*s)**2+(v*r)**2),we=Math.sqrt((m*s)**2+(y*r)**2),xe=Math.max($e,Tt,we);function ct(dt,be,Ye){const bt=1<>>31),dt>0&&(nr===0||bh*n>>0;for(let Ch=Sh;Ch{if(!b&&!o(y,S,w)){g=Math.max(y,g);return}if(y=e)throw new Error("Invalid node reference");const r=i[s*5],o=i[s*5+1],a=i[s*5+2],l=i[s*5+3],c=i[s*5+4];if(l<0||c<0||ce||l+8>>1!==r||h>>>1!==o||p>>>1!==a)throw new Error("invalid child");n(d)}}if(e!==0&&(n(e-1),t.size!==e))throw new Error("Orphan nodes in octree")}function pm(i,e,t){return`${i}/${e}:${t}`}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Gi extends vp{draw(e,t){}isReady(e,t){return!0}get transparentPickEnabled(){return!0}}var Sa=G(9254);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const vd=3,uD=.8,bi=!1;let kn=0,Pn=0,fm=0,gm=0;class Or{constructor(e=Or.generateHashSeeds(vd)){this.hashSeeds=e,this.loadFactor=uD,this.size=0,this.emptyLow=4294967295,this.emptyHigh=4294967295,this.maxRehashAttempts=5,this.maxAttempts=5,this.generation=0,this.mungedEmptyKey=-1;let t=8;for(;t<2*e.length;)t*=2;this.allocate(t)}updateHashFunctions(e){this.hashSeeds=Or.generateHashSeeds(e),this.mungedEmptyKey=-1}tableWithMungedEmptyKey(e){const t=this.hashSeeds.length,n=new Array(t);for(let l=0;l>>0;for(let l=0;l>>0,o=Math.random()*4294967296>>>0,!(!(r===e&&o===t)&&!this.hasPair(r,o)););this.emptyLow=r,this.emptyHigh=o;for(let a=0,l=n.length;athis.capacity?(this.backupPending(),this.grow(e),this.restorePending(),!0):!1}swapPending(e,t){const n=kn,s=Pn;this.storePending(e,t),e[t]=n,e[t+1]=s}storePending(e,t){kn=e[t],Pn=e[t+1]}backupPending(){fm=kn,gm=Pn}restorePending(){kn=fm,Pn=gm}tryToInsert(){bi&&console.log(`tryToInsert: ${kn}, ${Pn}`);let e=0;const{emptyLow:t,emptyHigh:n,maxAttempts:s,table:r}=this,o=this.hashSeeds.length;let a=Math.floor(Math.random()*o);for(;;){const l=this.getHash(a,kn,Pn);if(this.swapPending(r,l),kn===t&&Pn===n)return!0;if(++e===s)break;a=(a+Math.floor(Math.random()*(o-1))+1)%o}return!1}allocate(e){this.tableSize=e;const{entryStride:t}=this;this.table=new Uint32Array(e*t),this.maxAttempts=e,this.clearTable(),this.capacity=e*this.loadFactor,this.mungedEmptyKey=-1}rehash(e,t){bi&&console.log("rehash begin"),this.allocate(t),this.updateHashFunctions(this.hashSeeds.length);const{emptyLow:n,emptyHigh:s,entryStride:r}=this;for(let o=0,a=e.length;othis.capacity&&(this.backupPending(),this.grow(this.tableSize*2),this.restorePending());!this.tryToInsert();)this.backupPending(),this.grow(this.tableSize),this.restorePending()}}class mm extends Or{add(e){const{low:t,high:n}=e;return this.hasPair(t,n)?!1:(bi&&console.log(`add: ${t},${n}`),kn=t,Pn=n,this.insertInternal(),!0)}[Symbol.iterator](){return this.unsafeKeys()}}mm.prototype.entryStride=2;let _r=0,Vr=0,vm=0,ym=0;class yd extends Or{set(e,t){const{low:n,high:s}=e;return this.hasPair(n,s)?!1:(bi&&console.log(`add: ${n},${s} -> ${t.low},${t.high}`),kn=n,Pn=s,_r=t.low,Vr=t.high,this.insertInternal(),!0)}get(e,t){const n=this.indexOf(e);if(n===-1)return!1;const{table:s}=this;return t.low=s[n+2],t.high=s[n+3],!0}swapPending(e,t){const n=_r,s=Vr;super.swapPending(e,t),e[t+2]=n,e[t+3]=s}storePending(e,t){super.storePending(e,t),_r=e[t+2],Vr=e[t+3]}backupPending(){super.backupPending(),vm=_r,ym=Vr}restorePending(){super.restorePending(),_r=vm,Vr=ym}[Symbol.iterator](){return this.unsafeEntries()}*entries(){const{emptyLow:e,emptyHigh:t,entryStride:n}=this,{table:s}=this;for(let r=0,o=s.length;r4)break;return i.texelsPerElement=1,i.textureInternalFormat=pD[t],i.textureFormat=zi[t],i.texelType=WebGL2RenderingContext.UNSIGNED_BYTE,i.arrayElementsPerTexel=t,i.arrayConstructor=Uint8Array,i.samplerPrefix="u",i;case R.INT8:if(t<1||t>4)break;return i.texelsPerElement=1,i.textureInternalFormat=fD[t],i.textureFormat=zi[t],i.texelType=WebGL2RenderingContext.BYTE,i.arrayElementsPerTexel=t,i.arrayConstructor=Int8Array,i.samplerPrefix="i",i;case R.UINT16:if(t<1||t>4)break;return i.texelsPerElement=1,i.textureInternalFormat=gD[t],i.textureFormat=zi[t],i.texelType=WebGL2RenderingContext.UNSIGNED_SHORT,i.arrayElementsPerTexel=t,i.arrayConstructor=Uint16Array,i.samplerPrefix="u",i;case R.INT16:if(t<1||t>4)break;return i.texelsPerElement=1,i.textureInternalFormat=mD[t],i.textureFormat=zi[t],i.texelType=WebGL2RenderingContext.SHORT,i.arrayElementsPerTexel=t,i.arrayConstructor=Int16Array,i.samplerPrefix="i",i;case R.UINT32:if(t<1||t>4)break;return i.texelsPerElement=1,i.textureInternalFormat=Sm[t],i.textureFormat=zi[t],i.texelType=WebGL2RenderingContext.UNSIGNED_INT,i.arrayElementsPerTexel=1,i.arrayConstructor=Uint32Array,i.samplerPrefix="u",i;case R.INT32:if(t<1||t>4)break;return i.texelsPerElement=1,i.textureInternalFormat=vD[t],i.textureFormat=zi[t],i.texelType=WebGL2RenderingContext.INT,i.arrayElementsPerTexel=1,i.arrayConstructor=Int32Array,i.samplerPrefix="i",i;case R.UINT64:if(t<1||t>2)break;return i.texelsPerElement=1,i.textureInternalFormat=Sm[t*2],i.textureFormat=zi[t*2],i.texelType=WebGL2RenderingContext.UNSIGNED_INT,i.arrayElementsPerTexel=2*t,i.arrayConstructor=Uint32Array,i.samplerPrefix="u",i;case R.FLOAT32:if(t<1||t>4)break;return i.texelsPerElement=1,i.textureInternalFormat=yD[t],i.textureFormat=hD[t],i.texelType=WebGL2RenderingContext.FLOAT,i.arrayElementsPerTexel=t,i.arrayConstructor=Float32Array,i.samplerPrefix="",i}throw new Error(`No supported texture format for ${R[e]}[${t}].`)}function wa(i,e,t){const{arrayConstructor:n,arrayElementsPerTexel:s,textureInternalFormat:r,textureFormat:o,texelsPerElement:a}=e,{maxTextureSize:l}=i,c=t.length/s;if(c*a>l*l)throw new Error("Number of elements exceeds maximum texture size: "+a+" * "+c);const d=Math.ceil(c/l),u=Math.ceil(Math.log2(d)),h=(1<> log2width); + highp int x = int((index - (uint(y) << log2width)) * ${e}u); +`;for(let s=0;s> 17u); + value *= 0x1b873593u; + state ^= value; + state = (state << 13u) | (state >> 19u); + state = (state * 5u) + 0xe6546b64u; + return state; +} +highp uint hashCombine(highp uint state, uint64_t x) { + state = hashCombine(state, x.value[0]); + return hashCombine(state, x.value[1]); +} +`],xD=Wi(new Ns,R.UINT64,1);class Hi extends T.O8{constructor(e,t){super(),this.gl=e,this.hashTable=t,this.generation=-1,this.texture=null,this.texture=e.createTexture()}copyToGPU(){const{hashTable:e}=this,{generation:t}=e;if(this.generation===t)return;const{gl:n,texture:s}=this;this.generation=t,n.activeTexture(WebGL2RenderingContext.TEXTURE0+n.tempTextureUnit),n.bindTexture(WebGL2RenderingContext.TEXTURE_2D,s),e.tableWithMungedEmptyKey(r=>{wa(this.gl,xD,r)}),n.bindTexture(WebGL2RenderingContext.TEXTURE_2D,null)}disposed(){const{gl:e}=this;e.deleteTexture(this.texture),this.texture=null,this.gl=void 0,this.hashTable=void 0,super.disposed()}static get(e,t){return e.memoize.get(t,()=>new Hi(e,t))}}class wm{constructor(e,t=vd){this.prefix=e,this.numAlternatives=t,this.textureUnitSymbol=Symbol.for(`gpuhashtable:${this.prefix}`),this.accessHelper=new xa(`gpuhashtable_${this.prefix}`),this.samplerName=this.prefix+"_sampler",this.hashSeedsName=this.prefix+"_seeds",this.hashKeyMask=this.prefix+"_keyMask",this.readTable=this.prefix+"_readTable"}defineShader(e){const{hashSeedsName:t,samplerName:n,numAlternatives:s,hashKeyMask:r}=this;e.addUniform("highp uint",t,s),e.addUniform("highp uint",r),e.addTextureSampler("usampler2D",n,this.textureUnitSymbol),e.addFragmentCode(Cm),e.addFragmentCode(gt),e.addFragmentCode(Tp),this.accessHelper.defineShader(e),e.addFragmentCode(this.accessHelper.getAccessor(this.readTable,this.samplerName,R.UINT64,1));let o="";o+=` +bool ${this.hasFunctionName}(uint64_t x) { +`;for(let a=0;a>= 8u; +`;n+=` + vec3 hsv = vec3(v.x, 0.5 + v.y * 0.5, 1.0); + return hsvToRgb(hsv); +} +`,e.addFragmentCode(n)}enable(e,t,n){e.uniform1ui(t.uniform(this.seedName),n)}}const Tm=new Float32Array(3);function Dm(i){return`rgb(${i[0]*100}%,${i[1]*100}%,${i[2]*100}%)`}class Sd{constructor(e=ut()){this.hashSeed=e,this.changed=new j.IY}static getDefault(){return new Sd(0)}get value(){return this.hashSeed}set value(e){e!==this.hashSeed&&(this.hashSeed=e,this.changed.dispatch())}compute(e,t){let n=(0,Sa._)(this.hashSeed,t.low);n=(0,Sa._)(n,t.high);const s=(n&255)/255,r=(n>>8&255)/255;return Mo(e,s,.5+.5*r,1),e}computeCssColor(e){return this.compute(Tm,e),Dm(Tm)}randomize(){this.hashSeed=ut(),this.changed.dispatch()}toString(){return`new SegmentColorHash(${this.hashSeed})`}toJSON(){return this.hashSeed===0?void 0:this.hashSeed}reset(){this.restoreState(0)}restoreState(e){const t=e>>>0;t!==this.hashSeed&&(this.hashSeed=t,this.changed.dispatch())}}class TD{constructor(e){this.prefix=e,this.hashMapShaderManager=new xm("segmentStatedColorHash")}defineShader(e){this.hashMapShaderManager.defineShader(e);const t=` +bool ${this.getFunctionName}(uint64_t x, out vec4 value) { + uint64_t uint64Value; + if (${this.hashMapShaderManager.getFunctionName}(x, uint64Value)) { + uint uintValue = uint64Value.value[0]; + value.r = float((uintValue & 0x0000ffu)) / 255.0; + value.g = float((uintValue & 0x00ff00u) >> 8) / 255.0; + value.b = float((uintValue & 0xff0000u) >> 16) / 255.0; + value.a = float((uintValue & 0xff000000u) >> 24) / 255.0; + return true; + } + return false; +} +`;e.addFragmentCode(t)}get getFunctionName(){return`${this.prefix}_get`}enable(e,t,n){this.hashMapShaderManager.enable(e,t,n)}disable(e,t){this.hashMapShaderManager.disable(e,t)}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */let bd;function DD(){if(bd===void 0){const i=new Ae;i.set("keyl","recolor"),i.set("keyx","clear-segments"),i.set("keys","toggle-show-slices"),i.set("keyb","toggle-scale-bar"),i.set("keyv","toggle-default-annotations"),i.set("keya","toggle-axis-lines"),i.set("keyo","toggle-orthographic-projection");for(let e=1;e<=9;++e)i.set("digit"+e,"toggle-layer-"+e),i.set("control+digit"+e,"select-layer-"+e),i.set("alt+digit"+e,"toggle-pick-layer-"+e);for(let e=0;e<26;++e){const t=String.fromCharCode(97+e),n=String.fromCharCode(65+e);i.set(`alt?+control?+shift+key${t}`,`tool-${n}`)}i.set("keyn","add-layer"),i.set("keyh","help"),i.set("space","toggle-layout"),i.set("shift+space","toggle-layout-alternative"),i.set("backslash","toggle-show-statistics"),i.set("alt+arrowup","select-previous"),i.set("alt+arrowdown","select-next"),bd=i}return bd}let Cd;function Br(){return Cd===void 0&&(Cd=Ae.fromObject({"control+mousedown2":"select-position"})),Cd}let wd;function Im(){return wd===void 0&&(wd=Ae.fromObject({click0:"pin-annotation",mousedown2:"move-to-annotation"},{parents:[[Br(),0]]})),wd}let xd;function Lm(){return xd===void 0&&(xd=Ae.fromObject({arrowleft:"x-",arrowright:"x+",arrowup:"y-",arrowdown:"y+",comma:"z-",period:"z+",bracketleft:"t-",bracketright:"t+",keyz:"snap","control+equal":"zoom-in","alt+equal":"depth-range-decrease","control+shift+equal":"zoom-in","alt+shift+equal":"depth-range-decrease","control+minus":"zoom-out","alt+minus":"depth-range-increase",keyr:"rotate-relative-z-",keye:"rotate-relative-z+","shift+arrowdown":"rotate-relative-x-","shift+arrowup":"rotate-relative-x+","shift+arrowleft":"rotate-relative-y-","shift+arrowright":"rotate-relative-y+","control+wheel":{action:"zoom-via-wheel",preventDefault:!0},"alt+wheel":{action:"adjust-depth-range-via-wheel",preventDefault:!0},"at:wheel":{action:"z+1-via-wheel",preventDefault:!0},"at:shift+wheel":{action:"z+10-via-wheel",preventDefault:!0},"at:dblclick0":"select","at:shift+dblclick0":"star","at:control+mousedown0":"annotate","at:mousedown2":"move-to-mouse-position","at:alt+mousedown0":"move-annotation","at:control+alt+mousedown2":"delete-annotation","at:touchpinch":"zoom-via-touchpinch","at:touchrotate":"rotate-in-plane-via-touchrotate","at:touchtranslate2":"translate-in-plane-via-touchtranslate","at:touchhold1":"move-to-mouse-position","at:touchtap1x2":"select","at:touchtap2x3":"snap"},{label:"All Data Panels",parents:[[Br(),0]]})),xd}let Ed;function ID(){return Ed===void 0&&(Ed=Ae.fromObject({"at:mousedown0":{action:"rotate-via-mouse-drag",stopPropagation:!0},"at:shift+mousedown0":{action:"translate-via-mouse-drag",stopPropagation:!0},"at:touchtranslate1":"rotate-out-of-plane-via-touchtranslate"},{parents:[[Lm(),Number.NEGATIVE_INFINITY]]})),Ed}let Td;function LD(){return Td===void 0&&(Td=Ae.fromObject({"at:mousedown0":{action:"translate-via-mouse-drag",stopPropagation:!0},"at:shift+mousedown0":{action:"rotate-via-mouse-drag",stopPropagation:!0},"at:touchtranslate1":"translate-z-via-touchtranslate"},{parents:[[Lm(),Number.NEGATIVE_INFINITY]]})),Td}function RD(i){i.global.addParent(DD(),Number.NEGATIVE_INFINITY),i.sliceView.addParent(LD(),Number.NEGATIVE_INFINITY),i.perspectiveView.addParent(ID(),Number.NEGATIVE_INFINITY)}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */let Os;const Fr=[];function kD(){if(Os===void 0){const i=Os=document.createElement("div");i.classList.add("neuroglancer-drag-status"),document.body.appendChild(i)}return Os}function PD(){Os!==void 0&&(Me(Os),Os.style.display="none")}function Rm(i){const e=kD();Me(e),typeof i=="string"?e.appendChild(document.createTextNode(i)):e.appendChild(i()),e.style.display=""}function km(i,e){(0,F.U8)(Fr,t=>!(t.target===i&&t.operation===e))}function Cn(i,e,t){km(i,e),Fr.push({target:i,operation:e,status:t}),Rm(t)}function kt(i,e){km(i,e);const t=Fr.length===0?void 0:Fr[Fr.length-1];t===void 0?PD():Rm(t.status)}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const _s="neuroglancer-drag-over",Pm={row:"row",column:"col"},AD={left:"right",right:"left",top:"bottom",bottom:"top"},Ci={left:"column",right:"column",top:"row",bottom:"row"},Ea={left:"row",right:"row",top:"column",bottom:"column"},Ji={row:"width",column:"height"},Am={row:"left",column:"top"},MD={row:"right",column:"bottom"},Mm={left:"marginLeft",right:"marginRight",top:"marginTop",bottom:"marginBottom"},Ta={left:-1,right:1,top:-1,bottom:1};class ji extends T.O8{constructor(e,t=new Si){super(),this.sidePanelManager=e,this.location=t,this.element=document.createElement("div"),this.visibility=new vt(vt.VISIBLE);const{element:n}=this;n.classList.add("neuroglancer-side-panel"),n.draggable=!0,n.addEventListener("dragstart",s=>{this.sidePanelManager.startDrag(this.makeDragSource(),s),n.style.backgroundColor="black",setTimeout(()=>{n.style.backgroundColor=""},0),Cn(n,"drag",()=>document.createTextNode("Drag side panel to move it to the left/right/top/bottom of another panel"))}),n.addEventListener("dragend",s=>{this.sidePanelManager.endDrag(),kt(n,"drag")})}makeDragSource(){return{dropAsNewPanel:e=>{const t=this.location.value;this.location.value={...t,...e},this.location.locationChanged.dispatch()}}}close(){this.location.visible=!1}addTitleBar(e){const t=document.createElement("div");t.classList.add("neuroglancer-side-panel-titlebar");const{title:n}=e;let s;n!==void 0&&(s=document.createElement("div"),s.classList.add("neuroglancer-side-panel-title"),s.textContent=n,t.appendChild(s));const r=No({title:"Close panel",onClick:()=>{this.close()}});return r.style.order="100",t.appendChild(r),this.element.appendChild(t),{titleBar:t,titleElement:s,closeButton:r}}addBody(e){e.draggable=!0,e.addEventListener("dragstart",t=>{t.preventDefault(),t.stopPropagation()}),this.element.appendChild(e)}}class ND extends T.O8{constructor(e,t,n=new vt(vt.VISIBLE)){super(),this.display=e,this.center=t,this.visibility=n,this.element=document.createElement("div"),this.centerColumn=document.createElement("div"),this.beforeRender=new j.HN,this.sides={left:this.makeSidePanelSideState("left"),right:this.makeSidePanelSideState("right"),top:this.makeSidePanelSideState("top"),bottom:this.makeSidePanelSideState("bottom")},this.registeredPanels=new Set,this.layoutNeedsUpdate=!1,this.invalidateLayout=()=>{this.layoutNeedsUpdate=!0,this.display.scheduleRedraw()};const{element:s,centerColumn:r}=this;s.style.display="flex",s.style.flex="1",s.style.flexDirection="row",r.style.display="flex",r.style.flex="1",r.style.flexDirection="column",r.style.flexBasis="0px",r.style.minWidth="0px",this.render(),this.registerDisposer(e.updateStarted.add(()=>{this.beforeRender.dispatch(),this.layoutNeedsUpdate&&(this.render(),++e.resizeGeneration)})),this.registerDisposer(this.visibility.changed.add(this.invalidateLayout))}get visible(){return this.visibility.visible}makeSidePanelSideState(e){return{flexGroups:[],outerDropZoneElement:this.makeDropZone(e,Ta[e]*(1/0),0,e,!1)}}hasDroppablePanel(){return this.dragSource!==void 0}startDrag(e,t){setTimeout(()=>{this.dragSource===e&&(this.element.dataset.neuroglancerSidePanelDrag="true")},0),this.dragSource=e,t.stopPropagation(),t.dataTransfer.setData("neuroglancer-side-panel","")}endDrag(){delete this.element.dataset.neuroglancerSidePanelDrag,this.dragSource=void 0}makeDropZone(e,t,n,s,r=!1){const o=document.createElement("div");o.className="neuroglancer-side-panel-drop-zone";const a=10,l=Ci[s],c=Ea[s];return o.style[Ji[c]]=`${a}px`,o.style[Ji[l]]="100%",r?(o.style.position="absolute",o.style[s]="50%",o.style[Mm[s]]="-${size/2}px"):(o.style.position="relative",o.style[Mm[AD[s]]]=`-${a}px`),o.addEventListener("dragenter",d=>{this.hasDroppablePanel()&&(o.classList.add(_s),d.preventDefault(),Cn(o,"drop",()=>document.createTextNode(`Drop side panel as new ${l}`)))}),o.addEventListener("dragleave",()=>{kt(o,"drop"),o.classList.remove(_s)}),o.addEventListener("dragover",d=>{this.hasDroppablePanel()&&d.preventDefault()}),o.addEventListener("drop",d=>{const{dragSource:u}=this;if(u===void 0)return;kt(o,"drop"),o.classList.remove(_s);const h=Ci[e];u.dropAsNewPanel({side:e,row:h==="column"?n:t,col:h==="row"?n:t}),this.dragSource=void 0,d.preventDefault(),d.stopPropagation()}),o}registerPanel(e){return this.registeredPanels.add(e),this.invalidateLayout(),e.location.locationChanged.add(this.invalidateLayout),()=>{this.unregisterPanel(e)}}unregisterPanel(e){this.registeredPanels.delete(e),e.location.locationChanged.remove(this.invalidateLayout),e.panel?.dispose(),this.invalidateLayout()}disposed(){for(const{panel:e}of this.registeredPanels)e?.dispose();super.disposed()}render(){this.layoutNeedsUpdate=!1;const e={left:[],right:[],top:[],bottom:[]};for(const o of this.registeredPanels)e[o.location.value.side].push(o);const t=o=>this.renderSide(o,this.sides[o].flexGroups,e[o]),n=this;function*s(){yield n.sides.left.outerDropZoneElement,yield*t("left"),yield n.centerColumn,yield*t("right"),yield n.sides.right.outerDropZoneElement}nn(this.element,s());function*r(){yield n.sides.top.outerDropZoneElement,yield*t("top"),yield n.center,yield*t("bottom"),yield n.sides.bottom.outerDropZoneElement}nn(this.centerColumn,r())}makeCrossGutter(e,t){const n=document.createElement("div");n.style.position="relative";const s=Ea[e];n.className=`neuroglancer-resize-gutter-${s==="row"?"horizontal":"vertical"}`,n.addEventListener("pointerdown",o=>{if("button"in o&&o.button!==0)return;o.preventDefault();const a=this.sides[e].flexGroups[t];if(a===void 0||!a.visible)return;let c=a.element.getBoundingClientRect()[Ji[s]];const d=a.minSize,u=()=>{Cn(n,"drag",`Drag to resize, current ${Ji[s]} is ${a.crossSize}px`)};u(),zt(o,(h,p,m)=>{const g=s==="row"?p:m;c-=Ta[e]*g,a.crossSize=Math.max(d,Math.round(c)),u(),this.invalidateLayout()},()=>{kt(n,"drag")})});const r=this.makeDropZone(e,t-Ta[e]*.5,0,e,!0);return n.appendChild(r),n}makeFlexGutter(e,t,n){const s=document.createElement("div");s.style.position="relative";const r=Ci[e];s.className=`neuroglancer-resize-gutter-${r==="row"?"horizontal":"vertical"}`,s.addEventListener("pointerdown",a=>{if("button"in a&&a.button!==0)return;a.preventDefault();const l=this.sides[e].flexGroups[t];if(l===void 0||!l.visible)return;const{cells:c}=l,d=c[n];if(d===void 0||!d.registeredPanel.location.visible)return;let u=n+1;for(;u{Cn(s,"drag",`Drag to resize, current ${Ji[r]} ratio is ${d.registeredPanel.location.value.flex} : ${h.registeredPanel.location.value.flex}`)};p(),zt(a,m=>{const g=d.registeredPanel.panel,v=h.registeredPanel.panel;if(g===void 0||v===void 0)return;const y=g.element.getBoundingClientRect(),S=v.element.getBoundingClientRect(),w=Math.max(.1,Math.min(.9,r==="column"?(m.clientY-y.top)/(S.bottom-y.top):(m.clientX-y.left)/(S.right-y.left))),b=d.registeredPanel.location.value,x=h.registeredPanel.location.value,E=b.flex+x.flex;d.registeredPanel.location.value={...b,flex:Math.round(w*E*100)/100},h.registeredPanel.location.value={...x,flex:Math.round((1-w)*E*100)/100},p(),d.registeredPanel.location.locationChanged.dispatch(),h.registeredPanel.location.locationChanged.dispatch(),this.invalidateLayout()},()=>{kt(s,"drag")})});const o=this.makeDropZone(e,t,n+.5,Am[Ci[e]],!0);return s.appendChild(o),s}renderSide(e,t,n){const s=Pm[Ea[e]],r=Pm[Ci[e]];n.sort((l,c)=>{const d=l.location.value,u=c.location.value,h=d[r]-u[r];return h!==0?h:d[s]-u[s]});const o=this;function*a(){let l=0;const c=n.length;let d=0;for(;l0;let v=t[d];if(v===void 0){const S=o.makeCrossGutter(e,d),w=document.createElement("div");w.className=`neuroglancer-side-panel-${Ci[e]}`,v=t[d]={element:w,gutterElement:S,cells:[],crossSize:-1,minSize:m,visible:g,beginDropZone:o.makeDropZone(e,d,-1/0,Am[Ci[e]]),endDropZone:o.makeDropZone(e,d,1/0,MD[Ci[e]])}}else v.visible=g,v.minSize=m,v.crossSize=Math.max(v.crossSize,m);function*y(){yield v.beginDropZone;let S=0;for(let w=l,b=0;w1?`${D.flex}`:"1",yield L.element,S===p?E.gutterElement=void 0:(E.gutterElement===void 0&&(E.gutterElement=o.makeFlexGutter(e,d,b)),yield E.gutterElement)}yield v.endDropZone}nn(v.element,y()),v.cells.length=h-l,g&&(v.element.style[Ji[Ea[e]]]=`${v.crossSize}px`,Ta[e]>0?(yield v.gutterElement,yield v.element):(yield v.element,yield v.gutterElement)),l=h,++d}t.length=d}return a()}}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Nm(i={}){return Ne({text:"\u2197",...i})}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Om(i){return i.closest(".neuroglancer-selection-details")}class OD extends ji{constructor(e,t,n,s){super(e,t.location),this.sidePanelManager=e,this.state=t,this.manager=n,this.selectedLayer=s,this.body=document.createElement("div");const{element:r,body:o}=this;r.classList.add("neuroglancer-selection-details"),this.registerDisposer(new tn(this.element,Br()));const{titleBar:a}=this.addTitleBar({title:"Selection"}),l=Ne({svg:uf,title:"Previous selection",onClick:()=>{this.state.goBack()}}),c=Ne({svg:hf,title:"Next selection",onClick:()=>{this.state.goForward()}});a.appendChild(l),a.appendChild(c),a.appendChild(this.registerDisposer(new rn(t.pin,{text:"\u{1F4CC}\uFE0E",enableTitle:"Pin selection",disableTitle:"Unpin selection"})).element),o.classList.add("neuroglancer-selection-details-body"),this.addBody(o),o.appendChild(this.registerDisposer(new Wt(t,(d,u,h)=>{if(!t.location.visible||(l.style.visibility=t.canGoBack()?"visible":"hidden",c.style.visibility=t.canGoForward()?"visible":"hidden",d===void 0))return;const{position:p}=d;if(p!==void 0){const m=document.createElement("div");m.classList.add("neuroglancer-selection-details-position");const g=Hn({title:"Copy position",onClick:()=>{mi(S.map(b=>Math.floor(b)).join(", "))}});m.appendChild(g);const{coordinateSpace:{rank:v,names:y},position:S}=d;for(let b=0;b{this.manager.globalPosition.value=S}});m.appendChild(w),u.appendChild(m)}for(const m of d.layers){const{layer:g}=m;u.appendChild(h.registerDisposer(new Wt({value:void 0,changed:g.managedLayer.layerChanged},(v,y,S)=>{if(g.wasDisposed||!g.isReady)return;const w=document.createElement("div");if(w.classList.add("neuroglancer-selection-details-layer-body"),!g.displaySelectionState(m.state,w,S))return;const b=document.createElement("div");y.appendChild(b),b.classList.add("neuroglancer-selection-details-layer");const x=document.createElement("div");x.classList.add("neuroglancer-selection-details-layer-title"),x.textContent=g.managedLayer.name,x.addEventListener("click",()=>{this.selectedLayer.layer=g.managedLayer,this.selectedLayer.visible=!0}),x.title="Click to show layer side panel",b.appendChild(x),b.appendChild(w)})).element)}})).element)}close(){super.close(),this.state.value=void 0,this.state.pin.value=!0}}var _m=G(9564);/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Vm(i={}){const e=Ne({svg:_m,...i});return e.classList.add("neuroglancer-eye-icon"),e}var _D=G(7237);/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function VD(i={}){return Ne({svg:_D,...i})}var BD=G(9187);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Bm(i={}){const e=Ne({svg:BD,...i});return e.classList.add("neuroglancer-star-icon"),e}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class wi{constructor(e,t,n){this.key=e,this.value=t,this.label=n}toString(){const{key:e,value:t,label:n}=this;let s;return t===void 0?s=`${e}`:s=`${e}\u2192${t}`,n===void 0?s:`${s} ${n}`}}class FD extends T.O8{constructor(){super(...arguments),this.selectedSegment=new P.R,this.baseSelectedSegment=new P.R,this.hasSelectedSegment=!1,this.changed=new j.IY}get value(){return this.hasSelectedSegment?this.selectedSegment:void 0}get baseValue(){return this.hasSelectedSegment?this.baseSelectedSegment:void 0}set(e,t=!1){const{selectedSegment:n,baseSelectedSegment:s}=this;let r=0,o=0,a=0,l=0,c;if(e==null)c=!1;else if(typeof e=="number")r=a=e>>>0,o=l=e<0?4294967295:0,c=!0;else if(e instanceof wi){const d=e.value||e.key;r=d.low,o=d.high,a=e.key.low,l=e.key.high,c=!0}else e instanceof P.R?(r=a=e.low,o=l=e.high,c=!0):c=!1;t&&r===0&&o===0&&(c=!1),c?c&&(!this.hasSelectedSegment||n.low!==r||n.high!==o||s.low!==a||s.high!==l)&&(n.low=r,n.high=o,s.low=a,s.high=l,this.hasSelectedSegment=!0,this.changed.dispatch()):this.hasSelectedSegment&&(this.hasSelectedSegment=!1,this.changed.dispatch())}isSelected(e){return this.hasSelectedSegment&&P.R.equal(e,this.selectedSegment)}bindTo(e,t){this.registerDisposer(e.changed.add(()=>{const n=e.get(t);let s;n!==void 0&&(s=n.value),this.set(s,t.displayState.segmentationGroupState.value.hideSegmentZero.value)}))}}function Ur(i){i.useTemporarySegmentEquivalences.value=!1,i.useTemporaryVisibleSegments.value=!1,i.temporaryVisibleSegments.clear(),i.temporarySegmentEquivalences.clear()}function Fm(i,e,t=!1){let n,s,r;if(typeof e=="number"?n=new P.R(e>>>0,e<0?4294967295:0):typeof e=="string"?n=P.R.parseString(e):n=t?e.clone():e,i==null)return n;const{segmentEquivalences:o,segmentPropertyMap:{value:a}}=i.segmentationGroupState.value;o.size!==0?(s=o.get(n),P.R.equal(s,n)?r=void 0:r=s):s=n;const l=a?.getSegmentLabel(s);return l===void 0&&r===void 0?n:new wi(n,r,l)}function Yi(i,e){if(e instanceof wi)return e;const t=Fm(i,e);return t instanceof P.R?new wi(t):t}function Um(i,e){const{length:t}=e;i.valuee.style.setProperty("--neuroglancer-segment-list-width",`${t}ch`),i.segmentationGroupState.value.maxIdLength)}const Dd=(()=>{const i=document.createElement("div");i.classList.add("neuroglancer-segment-list-entry");const e=document.createElement("div");e.classList.add("neuroglancer-segment-list-entry-sticky"),i.appendChild(e);const t=Hn({title:"Copy segment ID"});t.classList.add("neuroglancer-segment-list-entry-copy");const n=document.createElement("div");n.classList.add("neuroglancer-segment-list-entry-copy-container");const s=n.childElementCount;n.appendChild(t);const r=e.childElementCount;e.appendChild(n);const o=e.childElementCount,a=Vm({title:"Toggle segment visibility"});a.classList.add("neuroglancer-segment-list-entry-visible-checkbox"),e.appendChild(a);const l=document.createElement("div");l.classList.add("neuroglancer-segment-list-entry-id-container");const c=e.childElementCount;e.appendChild(l);const d=document.createElement("div");d.classList.add("neuroglancer-segment-list-entry-id");const u=l.childElementCount;l.appendChild(d);const h=Bm({title:"Star segment"});h.classList.add("neuroglancer-segment-list-entry-star");const p=e.childElementCount;e.appendChild(h);const m=document.createElement("span");m.classList.add("neuroglancer-segment-list-entry-name");const g=i.childElementCount;i.appendChild(m);const v=VD({title:"Filter by label"});v.classList.add("neuroglancer-segment-list-entry-filter");const y=i.childElementCount;i.appendChild(v);const S=i.childElementCount;return i.appendChild(hi.template()),{template:i,copyContainerIndex:r,copyIndex:s,visibleIndex:o,idContainerIndex:c,idIndex:u,labelIndex:g,filterIndex:y,starIndex:p,colorWidgetIndex:S,unmappedIdIndex:-1,unmappedCopyIndex:-1}})(),UD=(()=>{const i=Dd,e=i.template.cloneNode(!0),t=e.children[0],n=t.children[i.idContainerIndex],s=n.childElementCount,r=n.children[i.idIndex].cloneNode(!0);r.classList.add("neuroglancer-segment-list-entry-unmapped-id"),n.appendChild(r);const o=t.children[i.copyContainerIndex],a=o.childElementCount;return o.appendChild(o.children[i.copyIndex].cloneNode(!0)),{...i,template:e,unmappedIdIndex:s,unmappedCopyIndex:a}})();function $D(i){const e=Dd,t=e.template.cloneNode(!0),n=[];for(let s=0;s{const u=d.currentTarget,h=u.dataset.id,p=An;p.tryParseString(h),i.segmentSelectionState.set(p),Om(u)||i.selectSegment(p,!1)},t=d=>{const u=d.currentTarget,h=u.dataset.id,p=An;p.tryParseString(h),i.selectSegment(p,Om(u)?"toggle":!0)},n=()=>{i.segmentSelectionState.set(null)},s=d=>d.currentTarget.closest(".neuroglancer-segment-list-entry"),r=d=>{const u=s(d);mi(u.dataset.id),d.stopPropagation()},o=d=>{const u=s(d);mi(u.dataset.unmappedId),d.stopPropagation()},a=d=>{const h=s(d).dataset.id,p=An;p.tryParseString(h);const{selectedSegments:m,visibleSegments:g}=i.segmentationGroupState.value,v=!g.has(p);v&&m.add(p),g.set(p,v),d.stopPropagation(),d.preventDefault()},l=d=>{const h=s(d).dataset.id,p=An;p.tryParseString(h),i.filterBySegmentLabel(p),d.stopPropagation()},c=d=>{if(d.button!==2||d.ctrlKey||d.altKey||d.metaKey||d.shiftKey)return;const h=d.currentTarget.dataset.id,p=An;p.tryParseString(h),i.moveToSegment(p)};return(d,u)=>{const{children:h}=d,p=h[0].children;d.addEventListener("mousedown",c);const m=p[u.copyContainerIndex];u.unmappedCopyIndex!==-1&&m.children[u.unmappedCopyIndex].addEventListener("click",o),m.children[u.copyIndex].addEventListener("click",r),d.addEventListener("mouseenter",e),d.addEventListener("mouseleave",n),p[u.visibleIndex].addEventListener("click",a),h[u.filterIndex].addEventListener("click",l),d.addEventListener("action:select-position",t),p[u.starIndex].addEventListener("click",y=>{const w=s(y).dataset.id,b=An;b.tryParseString(w);const{selectedSegments:x}=i.segmentationGroupState.value;x.set(b,!x.has(b))});const v=new q(C.eR.fromValues(0,0,0));v.changed.add(()=>{const y=new P.R(Ie(v.value)),S=d.dataset.id,w=An;w.tryParseString(S),i.segmentStatedColors.value.delete(w),i.segmentStatedColors.value.set(w,y)}),new hi(v,void 0,h[u.colorWidgetIndex],()=>{const y=d.dataset.id,S=An;S.tryParseString(y),i.segmentStatedColors.value.delete(S)},!1)}}class Vs{constructor(e,t){if(this.displayState=e,this.template=t,e!==void 0){let n=$m.get(e);n===void 0&&(n=GD(e),$m.set(e,n)),this.registerEventHandlers=n}}static make(e,t){return new Vs(e,t?UD:Dd)}get(e){const{displayState:t}=this;return this.getWithNormalizedId(Yi(t,e))}getWithNormalizedId(e){const{displayState:t}=this,{template:n}=this,s=n.template.cloneNode(!0),r=e.key,o=e.value??r,a=o.toString();s.dataset.id=a;const{children:l}=s,c=l[0].children,d=c[n.idContainerIndex];d.children[n.idIndex].textContent=a;const{unmappedIdIndex:u}=n;if(t!==void 0?this.registerEventHandlers(s,n):c[n.visibleIndex].style.display="none",u!==-1){const h=d.children[u];if(P.R.equal(r,o)){h.style.display="none";const p=c[n.copyContainerIndex];p.children[n.unmappedCopyIndex].style.display="none"}else{const p=r.toString();s.dataset.unmappedId=p,h.textContent=p,t!==void 0&&Um(t.segmentationGroupState.value.maxIdLength,p)}}return l[n.labelIndex].textContent=e.label??"",t!==void 0&&(this.updateWithId(s,o),Um(t.segmentationGroupState.value.maxIdLength,a)),s}update(e){const t=An,n=e.dataset.id;n!==void 0&&(t.parseString(n),this.updateWithId(e,t))}updateWithId(e,t){const{children:n}=e,s=n[0].children,{template:r}=this,{displayState:o}=this,{segmentSelectionState:a}=o,{visibleSegments:l}=o.segmentationGroupState.value;s[r.visibleIndex].classList.toggle("neuroglancer-visible",l.has(t)),e.dataset.selected=(a.hasSelectedSegment&&P.R.equal(a.selectedSegment,t)).toString();const{selectedSegments:c}=o.segmentationGroupState.value;s[r.starIndex].classList.toggle("neuroglancer-starred",c.has(t));const d=s[r.idContainerIndex];let u=Rd(this.displayState,t);Gm(d.children[r.idIndex],u);const h=!!this.displayState?.segmentStatedColors.value.has(t);zm(n[r.colorWidgetIndex],u,h);const{unmappedIdIndex:p}=r;if(p!==-1){let m;if(o.baseSegmentColoring.value&&(m=e.dataset.unmappedId)!==void 0){const v=An;v.parseString(m),u=Rd(this.displayState,v)}else u=C.Oi;Gm(d.children[p],u);const g=!!this.displayState?.segmentStatedColors.value.has(t);zm(n[r.colorWidgetIndex],u,g)}}}function Gm(i,e){i.style.backgroundColor=Dm(e),i.style.color=Be(e)?"white":"black"}function zm(i,e,t){i.value=Ge(e.subarray(0,3)),i.classList.toggle("overridden",t)}class Wm extends Vs{constructor(e,t,n){const s=e.segmentationGroupState.value.segmentPropertyMap.value,r=(s?.numericalProperties??[]).filter(n),o=$D(r.length);super(e,o),this.parentElement=t,this.segmentPropertyMap=s,this.numericalProperties=r,(this.numericalPropertyWidths=new Array(this.numericalProperties.length)).fill(0)}getWithNormalizedId(e){const t=super.getWithNormalizedId(e),{numericalProperties:n}=this,{numericalPropertyIndices:s}=this.template;if(s.length>0){const r=this.segmentPropertyMap?.getSegmentInlineIndex(e.value??e.key)??-1;if(r!==-1){const{numericalPropertyWidths:o}=this;for(let a=0,l=s.length;ao[a]&&(o[a]=u,this.parentElement.style.setProperty(`--neuroglancer-column-${a}-width`,`${u}ch`)),t.children[s[a]].textContent=d}}}}return t}makeHeaderLabel(e,t,n){const s=document.createElement("span");s.textContent=e,s.classList.add("neuroglancer-segment-list-header-label"),s.classList.add("neuroglancer-segment-list-header-label"),e==="label"&&(n.style.textAlign="left");const r=document.createElement("span");r.classList.add("neuroglancer-segment-list-header-label-sort"),s.appendChild(r),r.textContent="\u25B2";const o=dx(s).width;return this.parentElement.style.setProperty(t,`${o}px`),n.appendChild(s),{id:e,label:s,sortIcon:r}}getHeader(){const{template:e}=this,t=e.template.cloneNode(!0),{children:n}=t,s=n[0].children,r=s[e.copyContainerIndex];r.style.visibility="hidden",s[e.visibleIndex].style.visibility="hidden",n[e.filterIndex].style.visibility="hidden";const o=s[e.idContainerIndex],a=[this.makeHeaderLabel("id","--neuroglancer-id-column-label-width",o.children[e.idIndex]),this.makeHeaderLabel("label","--neuroglancer-label-column-label-width",n[e.labelIndex])],{numericalProperties:l}=this,{numericalPropertyIndices:c}=this.template;for(let d=0,u=c.length;d{iT(n,s,t)},i.segmentationGroupState)),e.registerDisposer((0,_.aM)((n,s)=>{n.registerDisposer(s.segmentColorHash.changed.add(t)),n.registerDisposer(s.segmentDefaultColor.changed.add(t))},i.segmentationColorGroupState)),e.registerDisposer(i.saturation.changed.add(t)),e.registerDisposer(i.segmentSelectionState.changed.add(t)),e.registerDisposer(i.baseSegmentColoring.changed.add(t)),e.registerDisposer(i.hoverHighlight.changed.add(t)),e.registerDisposer(i.segmentStatedColors.changed.add(t))}function Hm(i,e){const t=e.redrawNeeded.dispatch;Bs(i,e,t),e.registerDisposer((0,_.aM)((n,s)=>{sT(n,s,t)},i.segmentationGroupState))}function zD(i,e){Hm(i,e),e.registerDisposer(i.objectAlpha.changed.add(e.redrawNeeded.dispatch))}function Ld(i,e){zD(i,e),e.registerDisposer(i.transform.changed.add(e.redrawNeeded.dispatch)),e.registerDisposer(i.renderScaleTarget.changed.add(e.redrawNeeded.dispatch)),e.registerDisposer(i.transparentPickEnabled.changed.add(e.redrawNeeded.dispatch))}const Jm=C.ln.create(),An=new P.R,Da=new P.R;function Rd(i,e,t=Jm){if(i==null)return t.fill(1),t;const n=i.segmentationColorGroupState.value,{segmentStatedColors:s}=n;if(s.size!==0&&n.segmentStatedColors.get(e,Da))return t[0]=(Da.low&255)/255,t[1]=((Da.low&65280)>>>8)/255,t[2]=((Da.low&16711680)>>>16)/255,t;const r=n.segmentDefaultColor.value;return r!==void 0?(t[0]=r[0],t[1]=r[1],t[2]=r[2],t):(n.segmentColorHash.compute(t,e),t)}function WD(i,e,t=1){const n=Jm;n[3]=t,Rd(i,e,n);let s=i.saturation.value;i.hoverHighlight.value&&i.segmentSelectionState.isSelected(e)&&(s>.5?s=s-=.5:s+=.5);for(let r=0;r<3;++r)n[r]=n[r]*s+(1-s);return n[0]*=t,n[1]*=t,n[2]*=t,n}function jm(i,e={}){for(const t of cg)e[t]=i[t].rpcId;return e}const HD=ar(Dr);class Ia extends HD{constructor(e,t,n){super(n),this.chunkManager=e,this.displayState=t;const s=t.segmentationGroupState.value;for(const r of cg)this.registerDisposer(s[r].addRef())}initializeCounterpartWithChunkManager(e){const{displayState:t}=this;e.chunkManager=this.chunkManager.rpcId,jm(t.segmentationGroupState.value,e),e.transform=this.registerDisposer(ft.makeFromExisting(this.chunkManager.rpc,this.displayState.transform)).rpcId,e.renderScaleTarget=this.registerDisposer(ft.makeFromExisting(this.chunkManager.rpc,this.displayState.renderScaleTarget)).rpcId,super.initializeCounterpart(this.chunkManager.rpc,e)}}function kd(i,e,t,n,s){const r=Math.min(1,i.objectAlpha.value),o=i.baseSegmentColoring.value;Rs(i.segmentationGroupState.value,(a,l)=>{const c=n?.registerUint64(e,a),d=t?WD(i,o?a:l,r):void 0;s(a,d,c,l)})}var JD=Object.defineProperty,jD=Object.getOwnPropertyDescriptor,Ym=(i,e,t,n)=>{for(var s=n>1?void 0:n?jD(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&JD(e,t,s),s};/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const YD=C.pB.create(),an=C.w0.create(),Qm=!1;function Km(i,e){e.vertexBuffer=At.fromData(i,e.meshData.vertexPositions,i.ARRAY_BUFFER,i.STATIC_DRAW),e.indexBuffer=At.fromData(i,e.meshData.indices,i.ELEMENT_ARRAY_BUFFER,i.STATIC_DRAW),e.normalBuffer=At.fromData(i,e.meshData.vertexNormals,i.ARRAY_BUFFER,i.STATIC_DRAW)}function qm(i){i.vertexBuffer.dispose(),i.indexBuffer.dispose(),i.normalBuffer.dispose()}const QD=` +highp vec3 decodeNormalOctahedronSnorm8(highp vec2 e) { + vec3 v = vec3(e.xy, 1.0 - abs(e.x) - abs(e.y)); + if (v.z < 0.0) v.xy = (1.0 - abs(v.yx)) * vec2(v.x > 0.0 ? 1.0 : -1.0, v.y > 0.0 ? 1.0 : -1.0); + return normalize(v); +} +`;function Xm(i){return i>=128&&(i=i-256),Math.max(-1,i/127)}function qV(i){let e=i.length;e-=1;const t=new Float32Array(Math.floor(i.length/2)*3);let n=0;for(let s=0;s0?1:-1),l=(1-Math.abs(a))*(l>0?1:-1));const d=Math.sqrt(a**2+l**2+c**2);t[n]=a/d,t[n+1]=l/d,t[n+2]=c/d,n+=3}return t}function Zm(i){return{defineShader:e=>{e.addAttribute("highp vec3","aVertexPosition"),e.addVertexCode("highp vec3 getVertexPosition() { return aVertexPosition; }")},bind(e,t,n){n.vertexBuffer.bindToVertexAttrib(t.attribute("aVertexPosition"),3,i,!0)},endLayer:(e,t)=>{e.disableVertexAttribArray(t.attribute("aVertexPosition"))}}}const KD={[bn.Pc.float32]:Zm(WebGL2RenderingContext.FLOAT),[bn.Pc.uint16]:Zm(WebGL2RenderingContext.UNSIGNED_SHORT),[bn.Pc.uint10]:{defineShader:i=>{i.addAttribute("highp uint","aVertexPosition"),i.addVertexCode(` +highp vec3 getVertexPosition() { + return vec3(float(aVertexPosition & 1023u), + float((aVertexPosition >> 10) & 1023u), + float((aVertexPosition >> 20) & 1023u)) / 1023.0; +} +`)},bind(i,e,t){t.vertexBuffer.bindToVertexAttribI(e.attribute("aVertexPosition"),1,WebGL2RenderingContext.UNSIGNED_INT)},endLayer:(i,e)=>{i.disableVertexAttribArray(e.attribute("aVertexPosition"))}}};class ev{constructor(e,t){this.fragmentRelativeVertices=e,this.vertexPositionFormat=t,this.tempLightVec=new Float32Array(4),this.vertexPositionHandler=KD[this.vertexPositionFormat]}beginLayer(e,t,n,s){const{lightDirection:r,ambientLighting:o,directionalLighting:a}=n,l=this.tempLightVec;C.eR.scale(l,r,a),l[3]=o,e.uniform4fv(t.uniform("uLightDirection"),l);const c=s.silhouetteRendering.value;c>0&&e.uniform1f(t.uniform("uSilhouettePower"),c)}setColor(e,t,n){e.uniform4fv(t.uniform("uColor"),n)}setPickID(e,t,n){e.uniform1ui(t.uniform("uPickID"),n)}beginModel(e,t,n,s){const{projectionParameters:r}=n;e.uniformMatrix4fv(t.uniform("uModelViewProjection"),!1,C.pB.multiply(YD,r.viewProjectionMat,s)),(0,C._A)(an,s),(0,C.Jh)(an,an,r.displayDimensionRenderInfo.canonicalVoxelFactors),C.w0.invert(an,an),C.w0.transpose(an,an),e.uniformMatrix3fv(t.uniform("uNormalMatrix"),!1,an)}drawFragmentHelper(e,t,n,s,r){this.vertexPositionHandler.bind(e,t,n);const{meshData:o}=n;n.normalBuffer.bindToVertexAttrib(t.attribute("aVertexNormal"),2,WebGL2RenderingContext.BYTE,!0),n.indexBuffer.bind();const{indices:a}=o;e.drawElements(o.strips?WebGL2RenderingContext.TRIANGLE_STRIP:WebGL2RenderingContext.TRIANGLES,r-s,a.BYTES_PER_ELEMENT===2?WebGL2RenderingContext.UNSIGNED_SHORT:WebGL2RenderingContext.UNSIGNED_INT,s*a.BYTES_PER_ELEMENT)}drawFragment(e,t,n){const{meshData:s}=n,{indices:r}=s;this.drawFragmentHelper(e,t,n,0,r.length)}drawMultiscaleFragment(e,t,n,s,r){const o=n.meshData.subChunkOffsets[s],a=n.meshData.subChunkOffsets[r];this.drawFragmentHelper(e,t,n,o,a)}endLayer(e,t){this.vertexPositionHandler.endLayer(e,t),e.disableVertexAttribArray(t.attribute("aVertexNormal"))}makeGetter(e){const t=e.registerDisposer((0,_.Uq)(n=>n>0,[e.displayState.silhouetteRendering]));return Ai(e,e.gl,{memoizeKey:`mesh/MeshShaderManager/${this.fragmentRelativeVertices}/${this.vertexPositionFormat}`,parameters:t,defineShader:(n,s)=>{this.vertexPositionHandler.defineShader(n),n.addAttribute("highp vec2","aVertexNormal"),n.addVarying("highp vec4","vColor"),n.addUniform("highp vec4","uLightDirection"),n.addUniform("highp vec4","uColor"),n.addUniform("highp mat3","uNormalMatrix"),n.addUniform("highp mat4","uModelViewProjection"),n.addUniform("highp uint","uPickID"),s&&n.addUniform("highp float","uSilhouettePower"),this.fragmentRelativeVertices&&(n.addUniform("highp vec3","uFragmentOrigin"),n.addUniform("highp vec3","uFragmentShape")),n.addVertexCode(QD);let r="";this.fragmentRelativeVertices?r+=` +highp vec3 vertexPosition = uFragmentOrigin + uFragmentShape * getVertexPosition(); +highp vec3 normalMultiplier = 1.0 / uFragmentShape; +`:r+=` +highp vec3 vertexPosition = getVertexPosition(); +highp vec3 normalMultiplier = vec3(1.0, 1.0, 1.0); +`,r+=` +gl_Position = uModelViewProjection * vec4(vertexPosition, 1.0); +vec3 origNormal = decodeNormalOctahedronSnorm8(aVertexNormal); +vec3 normal = normalize(uNormalMatrix * (normalMultiplier * origNormal)); +float absCosAngle = abs(dot(normal, uLightDirection.xyz)); +float lightingFactor = absCosAngle + uLightDirection.w; +vColor = vec4(lightingFactor * uColor.rgb, uColor.a); +`,s&&(r+=` +vColor *= pow(1.0 - absCosAngle, uSilhouettePower); +`),n.setVertexMain(r),n.setFragmentMain("emit(vColor, uPickID);")}})}}class La extends Gi{constructor(e,t,n){super(),this.chunkManager=e,this.source=t,this.displayState=n,this.meshShaderManager=new ev(!1,bn.Pc.float32),this.getShader=this.meshShaderManager.makeGetter(this),Ld(n,this),this.registerDisposer(n.silhouetteRendering.changed.add(this.redrawNeeded.dispatch));const s=this.backend=this.registerDisposer(new Ia(e,n,this.layerChunkProgressInfo));s.RPC_TYPE_ID=bn.Of,s.initializeCounterpartWithChunkManager({source:t.addCounterpartRef()}),s.visibility.add(this.visibility),this.registerDisposer(n.renderScaleHistogram.visibility.add(this.visibility))}get isTransparent(){const{displayState:e}=this;return e.objectAlpha.value<1||e.silhouetteRendering.value>0}get transparentPickEnabled(){return this.displayState.transparentPickEnabled.value}get gl(){return this.chunkManager.chunkQueueManager.gl}draw(e,t){if(!e.emitColor&&e.alreadyEmittedPickID)return;const{gl:n,displayState:s,meshShaderManager:r}=this;if(s.objectAlpha.value<=0)return;const o=lr(s.transform.value,e.projectionParameters.displayDimensionRenderInfo,t);if(o===void 0)return;const{shader:a}=this.getShader(e.emitter);if(a===null)return;a.bind(),r.beginLayer(n,a,e,this.displayState),r.beginModel(n,a,e,o);const l=this.source.chunks;let c=0,d=0;const{renderScaleHistogram:u}=this.displayState,h=this.source.fragmentSource.chunks;kd(s,this,e.emitColor,e.emitPickID?e.pickIDs:void 0,(p,m,g)=>{const v=Sn(p),y=l.get(v);if(++c,y!==void 0){++d,e.emitColor&&r.setColor(n,a,m),e.emitPickID&&r.setPickID(n,a,g),c+=y.fragmentIds.length;for(const S of y.fragmentIds){const{key:w}=this.source.getFragmentKey(v,S),b=h.get(w);b!==void 0&&b.state===Ue.GPU_MEMORY&&(r.drawFragment(n,a,b),++d)}}}),e.emitColor&&(u.begin(this.chunkManager.chunkQueueManager.frameNumberCounter.frameNumber),u.add(Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY,d,c-d)),r.endLayer(n,a)}isReady(){const{displayState:e,source:t}=this;let n=!0;const s=t.fragmentSource.chunks;return Rs(e.segmentationGroupState.value,r=>{const o=Sn(r),a=t.chunks.get(o);if(a===void 0){n=!1;return}for(const l of a.fragmentIds){const{key:c}=this.source.getFragmentKey(o,l),d=s.get(c);if(d===void 0||d.state!==Ue.GPU_MEMORY){n=!1;return}}}),n}getObjectPosition(e,t){const n=this.displayState.transform.value;if(n.error!==void 0)return;const s=Sn(e),r=this.source.chunks.get(s);if(r===void 0)return;const{rank:o}=n,a=new Float32Array(n.modelToRenderLayerTransform.length);De.DI(a,o+1,n.modelToRenderLayerTransform,o+1,o+1);const l=new Float32Array(o);De.vo(l,a,o+1,t,o);const{fragmentIds:c}=r;let d=0;const u=[];for(const S of c){const{key:w}=this.source.getFragmentKey(s,S),b=this.source.fragmentSource.chunks.get(w);if(b===void 0)continue;const{state:x,meshData:E}=b;x!==Ue.SYSTEM_MEMORY&&x!==Ue.GPU_MEMORY||(d+=E.vertexPositions.length/o,u.push(b))}const p=100*1e3/d,m=Math.max(1,Math.floor(1/p)),g=new Float32Array(o);let v=Number.POSITIVE_INFINITY;for(const S of u){const{meshData:w}=S,{vertexPositions:b}=w;if(!(b.length0}get transparentPickEnabled(){return this.displayState.transparentPickEnabled.value}get gl(){return this.chunkManager.chunkQueueManager.gl}draw(e,t){if(!e.emitColor&&e.alreadyEmittedPickID)return;const{gl:n,displayState:s,meshShaderManager:r}=this;if(s.objectAlpha.value<=0)return;const o=lr(s.transform.value,e.projectionParameters.displayDimensionRenderInfo,t);if(o===void 0)return;const{shader:a}=this.getShader(e.emitter);if(a===null)return;a.bind(),r.beginLayer(n,a,e,this.displayState);const{renderScaleHistogram:l}=this.displayState;e.emitColor&&l.begin(this.chunkManager.chunkQueueManager.frameNumberCounter.frameNumber),(0,C._A)(an,o),(0,C.Jh)(an,an,e.projectionParameters.displayDimensionRenderInfo.voxelPhysicalScales);const c=Math.abs(C.w0.determinant(an))**(1/3),{chunks:d}=this.source,u=this.source.fragmentSource.chunks,{projectionParameters:h}=e,p=C.pB.multiply(C.pB.create(),h.viewProjectionMat,o),m=(0,C._S)(new Float32Array(24),p),g=this.displayState.renderScaleTarget.value,{fragmentRelativeVertices:v}=this.source.format;r.beginModel(n,a,e,o);let y=0,S=0;kd(s,this,e.emitColor,e.emitPickID?e.pickIDs:void 0,(w,b,x)=>{const E=Sn(w),D=d.get(E);if(++y,D===void 0)return;++S;const{manifest:I}=D,{octree:L,chunkShape:N,chunkGridSpatialOrigin:k,vertexOffsets:O}=I;if(Qm)try{dD(L)}catch(V){console.log(`invalid octree for object=${w}: ${V.message}`)}e.emitColor&&r.setColor(n,a,b),e.emitPickID&&r.setPickID(n,a,x),hm(I,p,m,g,h.width,h.height,(V,z,Y)=>{const Q=tv(u,E,V,z);return e.emitColor&&l.add(I.lodScales[V]*c,Y,Q?1:0,Q?0:1),Q},(V,z,Y,Q)=>{const X=pm(E,V,z),ce=u.get(X),oe=L[5*z],Se=L[5*z+1],Ke=L[5*z+2],$e=1<{if(!u)return;const p=Sn(h),m=r.get(p);if(m===void 0){u=!1;return}const{manifest:g}=m;hm(g,l,c,d,a.width,a.height,(v,y)=>(u=u&&tv(o,p,v,y),u),()=>{})}),u}getObjectPosition(e){const t=this.displayState.transform.value;if(t.error!==void 0)return;const n=this.source.chunks.get(Sn(e));if(n===void 0)return;const{manifest:s}=n,{clipLowerBound:r,clipUpperBound:o}=s,{rank:a}=t,l=new Float32Array(a);for(let d=0;d<3;++d)l[d]=(r[d]+o[d])/2;const c=new Float32Array(a);return De.vo(c,t.modelToRenderLayerTransform,a+1,l,a),c}}class ZD extends Jn{constructor(e,t){super(e),this.manifest=t.manifest}}class eI extends Jn{constructor(e,t){super(e),this.meshData=t}copyToGPU(e){super.copyToGPU(e),Km(e,this)}freeGPUMemory(e){super.freeGPUMemory(e),qm(this)}}class Ra extends on{constructor(e,t){super(e,t),this.fragmentSource=this.registerDisposer(new Md(this.chunkManager,this)),this.format=t.format}static encodeOptions(e){return{format:e.format,...on.encodeOptions(e)}}initializeCounterpart(e,t){this.fragmentSource.initializeCounterpart(this.chunkManager.rpc,{}),t.fragmentSource=this.fragmentSource.addCounterpartRef(),t.format=this.format,super.initializeCounterpart(e,t)}getChunk(e){return new ZD(this,e)}}let Md=class extends on{constructor(i,e){super(i),this.meshSource=e}get key(){return this.meshSource.key}getChunk(i){return new eI(this,i)}};Md=Ym([Zt(bn.pi)],Md);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function XV(i){let e=0;const t=i.length;for(let n=0;n>>0,e=(e<<15|e>>>17)>>>0,e=Math.imul(e,461845907)>>>0,i^=e,i=(i<<13|i>>>19)>>>0,i=Math.imul(i,5)+3864292196>>>0,i}function tI(i,e){return i^=e,i^=i>>>16,i=Math.imul(i,2246822507)>>>0,i^=i>>>13,i*=3266489909,i^=i>>>16,i>>>0}function iv(i,e,t){let n=i;return n=nv(n,e),n=nv(n,t),tI(n,8)}function ka(i){return i^=i>>>16,i=Math.imul(i,2246822507),i^=i>>>13,i=Math.imul(i,3266489909),i^=i>>>16,i}function sv(i,e){return i<>>32-e}function ZV(i,e,t,n){let s=e,r=e,o=e,a=e;const l=597399067,c=2869860233,d=951274213;let u=Math.imul(n,c);u=sv(u,16),u=Math.imul(u,d),r^=u;let h=Math.imul(t,l);h=sv(h,15),h=Math.imul(h,c),s^=h;const p=8;return s^=p,r^=p,o^=p,a^=p,s=s+r>>>0,s=s+o>>>0,s=s+a>>>0,r=r+s>>>0,o=o+s>>>0,a=a+s>>>0,s=ka(s),r=ka(r),o=ka(o),a=ka(a),s=s+r>>>0,s=s+o>>>0,s=s+a>>>0,r=r+s>>>0,i.low=s,i.high=r,i}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class nI extends on{constructor(e,t){super(e,t),this.properties=t.properties}static encodeOptions(e){return{properties:e.properties}}}function iI(i,e,t){const n=i.length-1;for(;;){if(e=e&n,i[e]===0){i[e]=t;return}++e}}function Fs(i,e){return e<=255?new Uint8Array(i):e<=65535?new Uint16Array(i):new Uint32Array(i)}function sI(i){const e=i.length/2,n=2**(Math.ceil(Math.log2(e))+1),s=Fs(n,e+1);for(let r=0;rn.type==="tags"),this.labels=t?.properties.find(n=>n.type==="label"),this.numericalProperties=t?.properties.filter(n=>n.type==="number")??[]}getSegmentInlineIndex(e){const{inlineIdToIndex:t}=this;return t===void 0?-1:rI(t,this.segmentPropertyMap.inlineProperties.ids,e.low,e.high)}getSegmentLabel(e){const t=this.getSegmentInlineIndex(e);if(t===-1)return;const{labels:n,tags:s}=this;let r="";if(n!==void 0&&(r=n.values[t]),s!==void 0){const{tags:o,values:a}=s,l=a[t];for(let c=0,d=l.length;c0&&(r+=" "),r+="#",r+=u}}if(r.length!==0)return r}}function ov(i,e,t){for(let n=0,s=t.length;n{const l=e[o*2],c=e[o*2+1],d=e[a*2],u=e[a*2+1];return c-u||l-d});const s=new Uint32Array(t*2);for(let o=0;o{const{values:a}=o,l=new a.constructor(t);for(let c=0;c{const p=a[2*u+1],m=a[2*u],g=l[2*h+1],v=l[2*h];return p-g||m-v},u=>{r[u]=t,++t},u=>{o[u]=t,++t},(u,h)=>{r[u]=t,o[h]=t,++t});let c;if(t===n)c=a;else if(t===s)c=l;else{c=new Uint32Array(t*2);for(let u=0;uxt(t))},()=>{const t=pI(e);if(t!==void 0)return new oI(t)})}const gI=/^[,\s]*[0-9]+(?:[,\s]+[0-9]+)*[,\s]*$/;function mI(i,e){if(e.match(gI)!==null){const d=e.split(/[\s,]+/),u=[],h=new Set;for(let p=0,m=d.length;pd.toLowerCase()),a=i?.labels,l=[];let c;for(let d=0;d{const y=g.toLowerCase(),S=o.indexOf(y);if(S===-1){l.push({begin:v,end:u,message:`Invalid tag: ${g}`});return}if(g=r[S],t.includeTags.includes(g)||t.excludeTags.includes(g)){l.push({begin:v,end:u,message:`Duplicate tag: ${g}`});return}return g};if(h.startsWith("#")){const g=p(h.substring(1),d+1);g!==void 0&&t.includeTags.push(g);continue}if(h.startsWith("-#")){const g=p(h.substring(2),d+2);g!==void 0&&t.excludeTags.push(g);continue}if(h.startsWith("<")||h.startsWith(">")){let g=h.substring(1).toLowerCase();if(g!=="id"&&g!=="label"){const v=n?.find(y=>y.id.toLowerCase()===g&&(y.type==="number"||y.type==="label"||y.type==="string"));if(v===void 0){l.push({begin:d+1,end:u,message:`Invalid field: ${g}`});continue}g=v.id}if(t.sortBy.find(v=>v.fieldId===g)!==void 0){l.push({begin:d+1,end:u,message:`Duplicate sort field: ${g}`});continue}t.sortBy.push({order:h[0],fieldId:g});continue}if(h.startsWith("|")){let g=h.substring(1).toLowerCase();if(g==="id"||g==="label")continue;const v=n?.find(y=>y.id.toLowerCase()===g&&(y.type==="number"||y.type==="string"));if(v===void 0){l.push({begin:d+1,end:u,message:`Invalid field: ${g}`});continue}if(g=v.id,t.sortBy.find(y=>y.fieldId===g)||t.includeColumns.find(y=>y===g))continue;t.includeColumns.push(g);continue}if(h.startsWith("/")){if(t.regexp!==void 0){l.push({begin:d,end:u,message:"Only one regular expression allowed"});continue}if(t.prefix!==void 0){l.push({begin:d,end:u,message:"Prefix cannot be combined with regular expression"});continue}if(a===void 0&&r.length==0){l.push({begin:d,end:u,message:"No label property"});continue}try{t.regexp=new RegExp(h.substring(1))}catch{l.push({begin:d,end:u,message:"Invalid regular expression syntax"})}continue}const m=h.match(/^([a-zA-Z][a-zA-Z0-9_]*)(<|<=|=|>=|>)([0-9.].*)$/);if(m!==null){let g=m[1].toLowerCase();const v=m[2],y=i?.numericalProperties.find(I=>I.id.toLowerCase()===g);if(y===void 0){l.push({begin:d,end:d+g.length,message:`Invalid numerical field: ${g}`});continue}g=y.id;let S;try{S=qt(y.dataType,m[3])}catch(I){l.push({begin:d+m[1].length+m[2].length,end:u,message:I.message});continue}let w=t.numericalConstraints.find(I=>I.fieldId===g);w===void 0&&(w={fieldId:g,bounds:y.bounds},t.numericalConstraints.push(w));const b=Pe(y.bounds,w.bounds[0]),x=Pe(y.bounds,w.bounds[1]);let E=x,D=b;switch(v){case"<":E=H(y.dataType,S,-1);break;case"<=":E=S;break;case"=":E=D=S;break;case">=":D=S;break;case">":D=H(y.dataType,S,1);break}if(D=rt(b,D)>0?b:D,E=rt(x,E)<0?x:E,rt(D,E)>0){l.push({begin:d,end:u,message:"Constraint would not match any values"});continue}w.bounds=[D,E];continue}if(t.regexp!==void 0){l.push({begin:d,end:u,message:"Prefix cannot be combined with regular expression"});continue}if(a===void 0&&r.length==0){l.push({begin:d,end:u,message:"No label property"});continue}t.prefix!==void 0?t.prefix+=` ${h}`:t.prefix=h}return l.length>0?{errors:l}:(t.sortBy.length===0&&t.sortBy.push({fieldId:lv(i),order:"<"}),t)}function Nd(i){return"\\u"+i.toString(16).padStart(4,"0")}function vI(i,e){if(e.errors!==void 0)return{query:e,total:-1,count:0,errors:e.errors};if(e.ids!==void 0){const{ids:b}=e;return{query:e,total:-1,explicitIds:b,count:b.length}}const t=i?.segmentPropertyMap?.inlineProperties;if(t===void 0)return{query:e,count:0,total:-1};const n=t?.properties,s=t.ids.length/2,r=i?.tags?.tags?.length||0;let o=Fs(s,s);const a=Fs(r,r);a.fill(1);for(let b=0;b{const x=o.length;let E=0;for(let D=0;D{const x=i.tags.tagDescriptions,E=i.tags.tags;a.fill(0);for(let D=0;DE[D].match(b)!==null),x!==void 0&&l(D=>E[D].startsWith(x))}if(o.length==0&&b!==void 0||i.labels==null&&b!=null){o=Fs(s,s);for(let E=0;E0||u.length>0){const{values:b,tags:x}=h,E=[];for(const k of d)E.push([x.indexOf(k),1]);for(const k of u)E.push([x.indexOf(k),0]);E.sort((k,O)=>k[0]-O[0]);let D="^",I=0;const L=k=>{kb[k].match(N)!==null)}let p,m;const{numericalConstraints:g}=e;if(g.length>0){const b=i.numericalProperties,x=g.length,E=2**x-1;p=Fs(o.length,E);for(let L=0;LQ.id===N.fieldId),{values:O}=k,V=2**L,[z,Y]=N.bounds;for(let Q=0,X=o.length;Q=z&&ce<=Y)}}m=o,o=m.slice();const D=o.length;let I=0;for(let L=0;L0&&v.push(z)}b.push(...v),v=b}const y=(b,x)=>{if(b.type!=="number"){const{values:E}=b;o.sort((D,I)=>(0,kr.e)(E[D],E[I])*x)}else{const E=b.values;o.sort((D,I)=>(E[D]-E[I])*x)}},S=b=>{h!==void 0&&y(h,b);const x=i?.labels;x!==void 0&&y(x,b)},{sortBy:w}=e;for(let b=w.length-1;b>=0;--b){const{fieldId:x,order:E}=w[b],D=E==="<"?1:-1;if(x==="id"){if(b+1===w.length){if(E==="<")continue;o.reverse();continue}o.sort((I,L)=>D*(I-L))}else x==="label"?S(D):y(n.find(I=>I.id===x),D)}return{query:e,intermediateIndices:m,intermediateIndicesMask:p,indices:o,tags:v,count:o.length,total:s}}function yI(i,e,t){const{values:s}=e,[r,o]=t,a=o<=r?0:256/(o-r),l=new Uint32Array(258),{numericalConstraints:c}=i.query,d=c.findIndex(u=>u.fieldId===e.id);if(d===-1){const u=i.indices;for(let h=0,p=u.length;h>>0]}}else{const u=i.intermediateIndices,h=i.intermediateIndicesMask,p=2**c.length-1-2**d;for(let m=0,g=u.length;m>>0]}}return{queryResult:i,histogram:l,window:t}}function SI(i,e,t,n){if(i===void 0){t.length=0,n.length=0;return}const{numericalProperties:s}=i,r=s.length;if(e?.indices===void 0){t.length=0;return}for(let a=0;aa.toString()).join(", ");let n="";e=e;const{prefix:s,regexp:r}=e;s!==void 0?n=s:r!==void 0&&(n=`/${r}`);for(const a of e.includeTags)n.length>0&&(n+=" "),n+=`#${a}`;for(const a of e.excludeTags)n.length>0&&(n+=" "),n+=`-#${a}`;for(const a of e.numericalConstraints){const{fieldId:l,bounds:c}=a,[d,u]=c,h=i.numericalProperties.find(p=>p.id===l);if(!Bt(h.dataType,h.bounds,c)){if(rt(d,u)===0){n.length>0&&(n+=" "),n+=`${l}=${d}`;continue}if(rt(d,h.bounds[0])>0){n.length>0&&(n+=" ");const p=H(h.dataType,d,-1),m=d.toString(),g=p.toString();h.dataType!==R.FLOAT32||m.length<=g.length?n+=`${l}>=${m}`:n+=`${l}>${g}`}if(rt(u,h.bounds[1])<0){n.length>0&&(n+=" ");const p=H(h.dataType,u,1),m=u.toString(),g=p.toString();h.dataType!==R.FLOAT32||m.length<=g.length?n+=`${l}<=${m}`:n+=`${l}<${g}`}}}let{sortBy:o}=e;if(o.length===1){const a=o[0];a.order==="<"&&a.fieldId===lv(i)&&(o=[])}for(const a of o)n.length>0&&(n+=" "),n+=`${a.order}${a.fieldId}`;for(const a of e.includeColumns)n.length>0&&(n+=" "),n+=`|${a}`;return n}const Us=new P.R;function CI(i,e,t){if(e===void 0)return;const{explicitIds:n}=e;if(n!==void 0){n.forEach(t);return}const{indices:s}=e;if(s!==void 0){const{ids:r}=i.segmentPropertyMap.inlineProperties;for(let o=0,a=s.length;o{t.has(s)&&++n}),n}function dv(i,e,t,n){const s=i.includeTags.filter(o=>o!==e),r=i.excludeTags.filter(o=>o!==e);return n===!0&&(t?s:r).push(e),{...i,includeTags:s,excludeTags:r}}function xI(i){return i.ids!==void 0?!1:i.errors!==void 0?!0:!(i.numericalConstraints.length>0||i.includeTags.length>0||i.excludeTags.length>0||i.prefix||i.regexp)}function Pa(i,e){if(i===void 0||i.ids!==void 0||i.errors!==void 0)return!1;const{sortBy:t,includeColumns:n}=i;return t.find(s=>s.fieldId===e)!==void 0||n.includes(e)}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class EI extends Gt{constructor(e){super(),this.layer=e;const{element:t}=this;t.appendChild(this.registerDisposer(new Wt(e.displayState.segmentationGroupState.value.graph,(n,s,r)=>{n?.tabContents&&s.appendChild(n.tabContents(e,r,this))})).element)}}class Od{}class _d extends T.O8{constructor(e,t){super(),this.graph=e,this.segmentsState=t}createRenderLayers(e,t,n){return[]}}function e2(i,e){let t,n;const s=()=>{const{value:a}=e;if(a===void 0){n!==void 0&&(n(),n=void 0,t=void 0);return}t!=null&&Uint64.equal(t,a)||(n!==void 0&&(n(),n=void 0,t=void 0),n=i.trackSegment(a,l=>{t=l,e.value=l??void 0}))};s();const r=e.changed.add(s);return()=>{r(),n!==void 0&&(n(),n=void 0)}}var Vd=G(9100),TI=Object.defineProperty,DI=Object.getOwnPropertyDescriptor,II=(i,e,t,n)=>{for(var s=n>1?void 0:n?DI(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&TI(e,t,s),s};/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const LI="DisjointUint64Sets",uv="DisjointUint64Sets.add",hv="DisjointUint64Sets.clear",pv="DisjointUint64Sets.highBitRepresentativeChanged",fv="DisjointUint64Sets.deleteSet";let Ki=class extends vo{constructor(){super(...arguments),this.disjointSets=new Vd.I,this.changed=new j.IY}get value(){return this}static makeWithCounterpart(i,e){const t=new Ki;return t.disjointSets.visibleSegmentEquivalencePolicy=e,t.registerDisposer(e.changed.add(()=>{gv(t)})),t.initializeCounterpart(i),e.value&&gv(t),t}disposed(){this.disjointSets=void 0,this.changed=void 0,super.disposed()}link(i,e){if(this.disjointSets.link(i,e)){const{rpc:t}=this;return t&&t.invoke(uv,{id:this.rpcId,al:i.low,ah:i.high,bl:e.low,bh:e.high}),this.changed.dispatch(),!0}return!1}linkAll(i){for(let e=1,t=i.length;e{(0,f.$v)(t,(n,s)=>{e[s%2].parseString(String(n),10),s!==0&&this.link(e[0],e[1])})})}}assignFrom(i){this.clear(),i instanceof Ki&&(i=i.disjointSets);for(const[e,t]of i)this.link(e,t)}};Ki=II([yo(LI)],Ki);const $s=new P.R,Bd=new P.R;pt(uv,function(i){const e=this.get(i.id);$s.low=i.al,$s.high=i.ah,Bd.low=i.bl,Bd.high=i.bh,e.disjointSets.link($s,Bd)&&e.changed.dispatch()}),pt(hv,function(i){const e=this.get(i.id);e.disjointSets.clear()&&e.changed.dispatch()});function gv(i){i.rpc.invoke(pv,{id:i.rpcId,value:i.disjointSets.visibleSegmentEquivalencePolicy.value})}pt(pv,function(i){const e=this.get(i.id);e.disjointSets.visibleSegmentEquivalencePolicy.value=i.value}),pt(fv,function(i){const e=this.get(i.id);$s.low=i.l,$s.high=i.h,e.disjointSets.deleteSet($s)&&e.changed.dispatch()});/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class RI extends Od{constructor(){super(...arguments),this.spanningTreeEdges=new Map,this.equivalences=new Ki,this.connections=new Set,this.changed=new j.HN}link(e,t){this.equivalences.link(e,t);for(const n of this.connections)n.segmentsState.segmentEquivalences.link(e,t)}linkAll(e){this.equivalences.linkAll(e);for(const t of this.connections)t.segmentsState.segmentEquivalences.linkAll(e)}deleteSet(e){this.equivalences.deleteSet(e);for(const t of this.connections)t.segmentsState.segmentEquivalences.deleteSet(e)}normalizeAll(){for(const e of this.connections)Fd(e.segmentsState.visibleSegments,e.segmentsState.segmentEquivalences.disjointSets)}addSpanningTreeEdge(e,t){const n=e.toString(),s=t.toString(),{spanningTreeEdges:r}=this;let o=r.get(n);o===void 0&&(o=new Set,r.set(n,o));let a=r.get(s);a===void 0&&(a=new Set,r.set(s,a)),o.add(s),a.add(n)}removeSpanningTreeEdge(e,t){const n=e.toString(),s=t.toString(),{spanningTreeEdges:r}=this,o=r.get(n),a=r.get(s);o.delete(s),o.size===0&&r.delete(n),a.delete(n),a.size===0&&r.delete(s)}*getSpanningTreeNeighbors(e){const t=new P.R,n=this.spanningTreeEdges.get(e.toString());if(n!==void 0)for(const s of n)t.parseString(s),yield t}restoreState(e){const{equivalences:t,spanningTreeEdges:n}=this;if(t.clear(),n.clear(),e===void 0)return;const s=[new P.R,new P.R];(0,f.$v)(e,r=>{(0,f.$v)(r,(o,a)=>{s[a%2].parseString(String(o),10),a!==0&&t.link(s[0],s[1])&&this.addSpanningTreeEdge(s[0],s[1])})})}toJSON(){const{spanningTreeEdges:e}=this;if(e.size===0)return;const t=new Array;for(const[n,s]of e){const r=P.R.parseString(n);for(const o of s){const a=P.R.parseString(o);P.R.compare(r,a)>0||t.push([r,a])}}return t.sort((n,s)=>P.R.compare(n[0],s[0])||P.R.compare(n[1],s[1])),t.map(n=>n.map(s=>s.toString()))}get visibleSegmentEquivalencePolicy(){return Rt.y6.MIN_REPRESENTATIVE}async merge(e,t){const{equivalences:n}=this;return P.R.equal(n.get(e),n.get(t))?e:(this.addSpanningTreeEdge(e,t),this.link(e,t),this.normalizeAll(),this.changed.dispatch(),n.get(e))}async split(e,t){const n=this.computeSplit(e,t);if(n===void 0)throw new Error("Segments are already split");const{includeBaseSegments:s,includeRepresentative:r,excludeBaseSegments:o,excludeRepresentative:a}=n,{equivalences:l}=this;this.deleteSet(e),this.linkAll(s),this.linkAll(o);const c=(h,p)=>{for(const m of h)for(const g of this.getSpanningTreeNeighbors(m))P.R.equal(l.get(g),p)||this.removeSpanningTreeEdge(m,g)},d=l.get(e),u=l.get(t);c(s,d),c(o,u);for(const h of this.connections){const{selectedSegments:p,visibleSegments:m}=h.segmentsState;p.has(a)&&(p.delete(a),p.add(r),m.add(r))}return this.normalizeAll(),this.changed.dispatch(),{include:d,exclude:u}}trackSegment(e,t){return()=>{}}computeSplit(e,t){const{equivalences:n}=this,s=n.get(e);if(!P.R.equal(s,n.get(t)))return;const r=new Vd.I;for(const u of n.setElements(s))if(!P.R.equal(u,t))for(const h of this.getSpanningTreeNeighbors(u))P.R.equal(h,t)||r.link(u,h);const o=[],a=[],l=r.get(e);let c=e,d=t;for(const u of n.setElements(s))P.R.equal(r.get(u),l)?(o.push(u),P.R.compare(u,c)<0&&(c=u)):(a.push(u),P.R.compare(u,d)<0&&(d=u));return o.sort(P.R.compare),a.sort(P.R.compare),{includeBaseSegments:o,includeRepresentative:c,excludeBaseSegments:a,excludeRepresentative:d}}connect(e){const t=e.displayState.segmentationGroupState.value,n=new kI(this,t);return t.segmentEquivalences.assignFrom(this.equivalences),Fd(t.visibleSegments,t.segmentEquivalences.disjointSets),n.registerDisposer(t.visibleSegments.changed.add(n.registerCancellable((0,Fe.A)(()=>Fd(t.visibleSegments,t.segmentEquivalences.disjointSets),0)))),this.connections.add(n),n.registerDisposer(()=>{this.connections.delete(n)}),n}}function Fd(i,e){const t=[];for(const n of i.unsafeKeys()){const s=e.get(n);P.R.equal(n,s)||(t.push(s),i.delete(n))}for(const n of t)i.add(n)}class kI extends _d{computeSplit(e,t){return this.graph.computeSplit(e,t)}}var PI=G(3786);/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const mv=yr;function Aa(i,e){i.addVertexCode(wc),i.addUniform("highp vec3","uCircleParams"),i.addVarying("highp vec4","vCircleCoord"),i.addVertexCode(` +void emitCircle(vec4 position, float diameter, float borderWidth) { + gl_Position = position; + float totalDiameter = diameter + 2.0 * (borderWidth + uCircleParams.z); + if (diameter == 0.0) totalDiameter = 0.0; + vec2 circleCornerOffset = getQuadVertexPosition(vec2(-1.0, -1.0), vec2(1.0, 1.0)); + gl_Position.xy += circleCornerOffset * uCircleParams.xy * gl_Position.w * totalDiameter; + vCircleCoord.xy = circleCornerOffset; + if (borderWidth == 0.0) { + vCircleCoord.z = totalDiameter; + vCircleCoord.w = 1e-6; + } else { + vCircleCoord.z = diameter / totalDiameter; + vCircleCoord.w = uCircleParams.z / totalDiameter; + } +} +`),e?i.addFragmentCode(` +float getCircleAlphaMultiplier() { + return 1.0 - 2.0 * abs(0.5 - gl_FragCoord.z); +} +`):i.addFragmentCode(` +float getCircleAlphaMultiplier() { + return 1.0; +} +`),i.addFragmentCode(` +vec4 getCircleColor(vec4 interiorColor, vec4 borderColor) { + float radius = length(vCircleCoord.xy); + if (radius > 1.0) { + discard; + } + + float borderColorFraction = clamp((radius - vCircleCoord.z) / vCircleCoord.w, 0.0, 1.0); + float feather = clamp((1.0 - radius) / vCircleCoord.w, 0.0, 1.0); + vec4 color = mix(interiorColor, borderColor, borderColorFraction); + + return vec4(color.rgb, color.a * feather * getCircleAlphaMultiplier()); +} +`)}function Ma(i,e,t){const{gl:n}=i;n.uniform3f(i.uniform("uCircleParams"),1/e.width,1/e.height,Math.max(1e-6,t.featherWidthInPixels))}function Na(i,e,t){Ao(i,e,t)}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function xi(i){i.addAttribute("int","aDummyVertexId",0),i.addVertexCode(` +int getVertexId () { + return aDummyVertexId + gl_VertexID; +} +#define gl_VertexID (getVertexId()) +`)}class Qn extends T.O8{constructor(e){super(),this.buffer=new At(e),this.size=0}disposed(){this.buffer.dispose()}enable(e=256){const{buffer:t}=this,{gl:n}=t;t.bind(),e>this.size&&(this.size=e,n.bufferData(WebGL2RenderingContext.ARRAY_BUFFER,new Int32Array(e),WebGL2RenderingContext.STATIC_DRAW)),n.vertexAttribIPointer(0,1,WebGL2RenderingContext.INT,0,0),n.vertexAttribDivisor(0,0),n.enableVertexAttribArray(0)}disable(){const{gl:e}=this.buffer;e.disableVertexAttribArray(0)}static get(e){return e.memoize.get("VertexIdHelper",()=>new Qn(e))}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const AI=C.pB.create(),vv=`void main() { + emitDefault(); +} +`,Gr=[],MI=Wi(new Ns,R.FLOAT32,3);class yv extends T.O8{constructor(e,t){super(),this.base=e,this.targetIsSliceView=t,this.textureAccessHelper=new xa("vertexData"),this.vertexIdHelper=this.registerDisposer(Qn.get(this.gl)),this.edgeShaderGetter=Ai(this,this.gl,{memoizeKey:{type:"skeleton/SkeletonShaderManager/edge",vertexAttributes:this.vertexAttributes},fallbackParameters:this.base.fallbackShaderParameters,parameters:this.base.displayState.skeletonRenderingOptions.shaderControlState.builderState,shaderError:this.base.displayState.shaderError,defineShader:(n,s)=>{if(s.parseResult.errors.length!==0)throw new Error("Invalid UI control specification");this.defineCommonShader(n),this.defineAttributeAccess(n),In(n),n.addAttribute("highp uvec2","aVertexIndex"),n.addUniform("highp float","uLineWidth");let r=` +highp vec3 vertexA = readAttribute0(aVertexIndex.x); +highp vec3 vertexB = readAttribute0(aVertexIndex.y); +emitLine(uProjection, vertexA, vertexB, uLineWidth); +highp uint lineEndpointIndex = getLineEndpointIndex(); +highp uint vertexIndex = aVertexIndex.x * lineEndpointIndex + aVertexIndex.y * (1u - lineEndpointIndex); +`;n.addFragmentCode(` +vec4 segmentColor() { + return uColor; +} +void emitRGB(vec3 color) { + emit(vec4(color * uColor.a, uColor.a * getLineAlpha() * ${this.getCrossSectionFadeFactor()}), uPickID); +} +void emitDefault() { + emit(vec4(uColor.rgb, uColor.a * getLineAlpha() * ${this.getCrossSectionFadeFactor()}), uPickID); +} +`),n.addFragmentCode(Is);const{vertexAttributes:o}=this,a=o.length;for(let l=1;l{if(s.parseResult.errors.length!==0)throw new Error("Invalid UI control specification");this.defineCommonShader(n),this.defineAttributeAccess(n),Aa(n,this.targetIsSliceView),n.addUniform("highp float","uNodeDiameter");let r=` +highp uint vertexIndex = uint(gl_InstanceID); +highp vec3 vertexPosition = readAttribute0(vertexIndex); +emitCircle(uProjection * vec4(vertexPosition, 1.0), uNodeDiameter, 0.0); +`;n.addFragmentCode(` +vec4 segmentColor() { + return uColor; +} +void emitRGBA(vec4 color) { + vec4 borderColor = color; + emit(getCircleColor(color, borderColor), uPickID); +} +void emitRGB(vec3 color) { + emitRGBA(vec4(color, 1.0)); +} +void emitDefault() { + emitRGBA(uColor); +} +`),n.addFragmentCode(Is);const{vertexAttributes:o}=this,a=o.length;for(let l=1;l{e.addTextureSampler(`${Ca(s.dataType)}sampler2D`,`uVertexAttributeSampler${r}`,Gr[r]),e.addVertexCode(t.getAccessor(`readAttribute${r}`,`uVertexAttributeSampler${r}`,s.dataType,s.numComponents))})}getCrossSectionFadeFactor(){return this.targetIsSliceView?"(clamp(1.0 - 2.0 * abs(0.5 - gl_FragCoord.z), 0.0, 1.0))":"(1.0)"}beginLayer(e,t,n,s){const{viewProjectionMat:r}=n.projectionParameters,o=C.pB.multiply(AI,r,s);e.uniformMatrix4fv(t.uniform("uProjection"),!1,o),this.vertexIdHelper.enable()}setColor(e,t,n){e.uniform4fv(t.uniform("uColor"),n)}setPickID(e,t,n){e.uniform1ui(t.uniform("uPickID"),n)}drawSkeleton(e,t,n,s,r){const{vertexAttributes:o}=this,a=o.length,{vertexAttributeTextures:l}=s;for(let c=0;c(i[i.LINES=0]="LINES",i[i.LINES_AND_POINTS=1]="LINES_AND_POINTS",i))(Sv||{});class bv extends Oi.F{constructor(e,t=e){super(Sv,e,t)}}class Cv extends _.DN{constructor(e,t=e){super(e,f.Mo,t)}}class NI{constructor(){this.compound=new fr,this.shader=Co(vv),this.shaderControlState=new Jo(this.shader),this.params2d={mode:new bv(1),lineWidth:new Cv(2)},this.params3d={mode:new bv(0),lineWidth:new Cv(1)};const{compound:e}=this;e.add("shader",this.shader),e.add("shaderControls",this.shaderControlState),e.add("mode2d",this.params2d.mode),e.add("lineWidth2d",this.params2d.lineWidth),e.add("mode3d",this.params3d.mode),e.add("lineWidth3d",this.params3d.lineWidth)}get changed(){return this.compound.changed}reset(){this.compound.reset()}restoreState(e){e!==void 0&&this.compound.restoreState(e)}toJSON(){const e=this.compound.toJSON();for(const t of Object.values(e))if(t!==void 0)return e}}class OI extends T.O8{constructor(e,t,n){super(),this.chunkManager=e,this.source=t,this.displayState=n,this.layerChunkProgressInfo=new fo,this.redrawNeeded=new j.IY,this.fallbackShaderParameters=new _.B0(Ho(Er(vv))),Ld(n,this),this.displayState.shaderError.value=void 0;const{skeletonRenderingOptions:s}=n;this.registerDisposer(s.shader.changed.add(()=>{this.displayState.shaderError.value=void 0,this.redrawNeeded.dispatch()}));const r=this.sharedObject=this.registerDisposer(new Ia(e,n,this.layerChunkProgressInfo));r.RPC_TYPE_ID=PI.k,r.initializeCounterpartWithChunkManager({source:t.addCounterpartRef()});const o=this.vertexAttributes=[VI];for(const[a,l]of t.vertexAttributes)o.push({name:a,dataType:l.dataType,numComponents:l.numComponents,webglDataType:_I(l.dataType),glslDataType:l.numComponents>1?`vec${l.numComponents}`:"float"})}get visibility(){return this.sharedObject.visibility}get gl(){return this.chunkManager.chunkQueueManager.gl}draw(e,t,n,s,r){const o=s.lineWidth.value,{gl:a,source:l,displayState:c}=this;if(c.objectAlpha.value<=0)return;const d=lr(c.transform.value,e.projectionParameters.displayDimensionRenderInfo,r);if(d===void 0)return;let u;s.mode.value===1?u=Math.max(5,o*2):u=o;const h=n.edgeShaderGetter(e.emitter),p=n.nodeShaderGetter(e.emitter),{shader:m,parameters:g}=h,{shader:v,parameters:y}=p;if(m===null||v===null)return;const{shaderControlState:S}=this.displayState.skeletonRenderingOptions;m.bind(),n.beginLayer(a,m,e,d),vi(a,m,S,g.parseResult.controls),a.uniform1f(m.uniform("uLineWidth"),o),v.bind(),n.beginLayer(a,v,e,d),a.uniform1f(v.uniform("uNodeDiameter"),u),vi(a,v,S,y.parseResult.controls);const w=l.chunks;kd(c,t,e.emitColor,e.emitPickID?e.pickIDs:void 0,(b,x,E)=>{const D=Sn(b),I=w.get(D);I===void 0||I.state!==Ue.GPU_MEMORY||(x!==void 0&&(m.bind(),n.setColor(a,m,x),v.bind(),n.setColor(a,v,x)),E!==void 0&&(m.bind(),n.setPickID(a,m,E),v.bind(),n.setPickID(a,v,E)),n.drawSkeleton(a,m,v,I,e.projectionParameters))}),n.endLayer(a,m)}isReady(){const{source:e,displayState:t}=this;if(t.objectAlpha.value<=0)return!0;const n=e.chunks;let s=!0;return Rs(t.segmentationGroupState.value,r=>{const o=Sn(r),a=n.get(o);if(a===void 0||a.state!==Ue.GPU_MEMORY){s=!1;return}}),s}}class Ud extends Gi{constructor(e){super(),this.base=e,this.renderHelper=this.registerDisposer(new yv(this.base,!1)),this.renderOptions=this.base.displayState.skeletonRenderingOptions.params3d,this.layerChunkProgressInfo=e.layerChunkProgressInfo,this.registerDisposer(e),this.registerDisposer(e.redrawNeeded.add(this.redrawNeeded.dispatch));const{renderOptions:t}=this;this.registerDisposer(t.mode.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(t.lineWidth.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(e.visibility.add(this.visibility))}get gl(){return this.base.gl}get isTransparent(){return this.base.displayState.objectAlpha.value<1}draw(e,t){!e.emitColor&&e.alreadyEmittedPickID||this.base.draw(e,this,this.renderHelper,this.renderOptions,t)}isReady(){return this.base.isReady()}}class wv extends Fi{constructor(e){super(),this.base=e,this.renderHelper=this.registerDisposer(new yv(this.base,!0)),this.renderOptions=this.base.displayState.skeletonRenderingOptions.params2d,this.layerChunkProgressInfo=e.layerChunkProgressInfo,this.registerDisposer(e);const{renderOptions:t}=this;this.registerDisposer(t.mode.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(t.lineWidth.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(e.redrawNeeded.add(this.redrawNeeded.dispatch)),this.registerDisposer(e.visibility.add(this.visibility))}get gl(){return this.base.gl}draw(e,t){this.base.draw(e,this,this.renderHelper,this.renderOptions,t)}isReady(){return this.base.isReady()}}function _I(i){switch(i){case R.FLOAT32:return WebGL2RenderingContext.FLOAT;default:throw new Error(`Data type not supported by WebGL: ${R[i]}`)}}const VI={dataType:R.FLOAT32,numComponents:3,name:"",webglDataType:WebGL2RenderingContext.FLOAT,glslDataType:"vec3"};class BI extends Jn{constructor(e,t){super(e),this.vertexAttributes=t.vertexAttributes;const n=this.indices=t.indices;this.numVertices=t.numVertices,this.vertexAttributeOffsets=t.vertexAttributeOffsets,this.numIndices=n.length}copyToGPU(e){super.copyToGPU(e);const{attributeTextureFormats:t}=this.source,{vertexAttributes:n,vertexAttributeOffsets:s}=this,r=this.vertexAttributeTextures=[];for(let o=0,a=s.length;o(i[i.UNKNOWN=0]="UNKNOWN",i[i.IMAGE=1]="IMAGE",i[i.SEGMENTATION=2]="SEGMENTATION",i))(St||{});const t2=18;function $d(i){const{rank:e,dataType:t,fillValue:n=t===R.UINT64?P.R.ZERO:0,compressedSegmentationBlockSize:s}=i,{baseVoxelOffset:r=new Float32Array(e)}=i;return{...Ko(i),compressedSegmentationBlockSize:s,baseVoxelOffset:r,dataType:t,fillValue:n}}function $I(i){if(i.compressedSegmentationBlockSize!==void 0||i.volumeType!==2&&!i.volumeSourceOptions.discreteValues)return!1;switch(i.dataType){case R.UINT32:case R.UINT64:break;default:return!1}switch(i.rank){case 3:return!0;case 4:{const{chunkDataSize:e}=i;return e[3]===1}default:return!1}}function xv(i){const{rank:e,lowerVoxelBound:t,upperVoxelBound:n}=i;if(!$I(i))return $d(i);let{volumeSourceOptions:{displayRank:s,multiscaleToViewTransform:r},chunkToMultiscaleTransform:o,chunkToViewTransform:a}=i;a===void 0&&(a=De.lw(new Float32Array(e*s),s,r,s,o,e+1,s,e,e));const{maxCompressedSegmentationBlockSize:l,chunkDataSize:c}=i;return $d({...i,compressedSegmentationBlockSize:Float32Array.from(Qo({rank:e,chunkToViewTransform:a,displayRank:s,lowerVoxelBound:t,upperVoxelBound:n,maxVoxelsPerChunkLog2:9,maxBlockSize:l===void 0?c:uC(new Uint32Array(e),c,l)}))})}function qi(i){const{rank:e}=i,{volumeSourceOptions:{displayRank:t,multiscaleToViewTransform:n,modelChannelDimensionIndices:s},chunkToMultiscaleTransform:r}=i,o=De.lw(new Float32Array(t*e),t,n,t,r,e+1,t,e,e);let{minBlockSize:a}=i;a===void 0?(a=new Uint32Array(e),a.fill(1)):a=new Uint32Array(a);const{lowerVoxelBound:l,upperVoxelBound:c}=i;if(s.length!==0)for(const u of(0,C.PC)(r,e,s)){let h=c[u];l!==void 0&&(h-=l[u]),a[u]=h}const{chunkDataSizes:d=ME({...i,minBlockSize:a,chunkToViewTransform:o,displayRank:t})}=i;return d.map(u=>xv({...i,chunkDataSize:u,chunkToViewTransform:o}))}const n2="volume";/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Ev(i,e,t,n){const{dataType:s}=e;e.defineShader(i,t);let r="",o="";if(t===0)r+="highp int ignoredChannelIndex";else for(let l=0;l=l[g])return;if(t.channelSpaceShape.length===0)return a.getValueAt(r);const{numChannels:c,chunkChannelCoordinates:d,chunkChannelDimensionIndices:u}=t,h=u.length;let p=0;const m=new Array(c);for(let g=0;g{const i=[0,1,2,4,5,3,6,7],e=[0,1,2,5,3,4,6,7],t=[0,1,1,4,4,7,4,7,1,5,0,1,1,4,4,7,0,2,2,5,5,7,5,7,2,6,0,2,2,5,5,7,0,3,3,6,6,7,6,7,3,4,0,3,3,6,6,7],n=[0,1,2,3,4,5,6,7,1,4,5,0,3,7,2,6,2,6,0,5,7,3,1,4,3,0,6,4,1,2,7,5,4,3,7,1,0,6,5,2,5,2,1,7,6,0,4,3,6,7,3,2,5,4,0,1,7,5,4,6,2,1,3,0],s=new Int32Array(8*8*6);for(let r=0;r<8;++r)for(let o=0;o{e.gl.uniform3fv(e.uniform("uVertexBasePosition"),Gd)}),i.addVertexCode(` +vec3 getBoundingBoxPlaneIntersectionVertexPosition(vec3 chunkSize, vec3 boxLower, vec3 lowerClipBound, vec3 upperClipBound, int vertexIndex, float planeDistance) { + for (int e = 0; e < 4; ++e) { + highp ivec2 vidx = uVertexIndex[vertexIndex*4 + e]; + highp vec3 v1 = max(lowerClipBound, min(upperClipBound, chunkSize * uVertexBasePosition[vidx.x] + boxLower)); + highp vec3 v2 = max(lowerClipBound, min(upperClipBound, chunkSize * uVertexBasePosition[vidx.y] + boxLower)); + highp vec3 vDir = v2 - v1; + highp float denom = dot(vDir, uPlaneNormal); + if (abs(denom) > ${Iv}) { + highp float lambda = (planeDistance - dot(v1, uPlaneNormal)) / denom; + if ((lambda >= -${_a}) && (lambda <= (1.0 + ${_a}))) { + lambda = clamp(lambda, 0.0, 1.0); + highp vec3 position = v1 + lambda * vDir; + return position; + } + } + } + return vec3(0, 0, 0); +} +vec3 getBoundingBoxPlaneIntersectionVertexPosition(vec3 chunkSize, vec3 boxLower, vec3 lowerClipBound, vec3 upperClipBound, int vertexIndex) { + return getBoundingBoxPlaneIntersectionVertexPosition(chunkSize, boxLower, lowerClipBound, upperClipBound, vertexIndex, uPlaneDistance); +} +`)}function kv(i,e,t,n,s,r,o,a=!0){const l=Lv(s),c=Rv.subarray(l*48,(l+1)*48),d=[0,0],u=[C.eR.create(),C.eR.create()],h=C.eR.create(),p=C.eR.create(),m=g=>Gd.subarray(g*3,g*3+3);for(let g=0;g<4;++g){for(let y=0;y<2;++y)d[y]=c[2*(o*4+g)+y],C.eR.multiply(u[y],i,m(d[y])),C.eR.add(u[y],u[y],r),C.eR.min(u[y],u[y],t),C.eR.max(u[y],u[y],e);C.eR.subtract(h,u[1],u[0]);const v=C.eR.dot(h,s);if(Math.abs(v)>Iv){let y=(n-C.eR.dot(u[0],s))/v;if(y>=-_a&&y<=1+_a)return a&&console.log(`vertex ${o}, e = ${g}, good, lambda=${y}, denom=${v}, v0=${u[0].join()}, vDir=${h.join()}`),y=Math.max(0,Math.min(1,y)),C.eR.scaleAndAdd(p,u[0],h,y),p;a&&console.log(`vertex ${o}, e = ${g}, skipped, denom = ${v}, vDir = ${h.join()}, v0=${u[0].join()}, v1=${u[1].join()}uPlaneNormal = ${(0,C.nL)(s)}, lambda=${y}`)}else a&&console.log(`vertex ${o}, e = ${g}, skipped, deom = ${v}, vDir = ${(0,C.nL)(h)}, uPlaneNormal = ${(0,C.nL)(s)}, uLowerClipBound=${e.join()}, uUpperClipBound=${t.join()}, chunkSize=${i}, uVertexBasePosition(v0)=${m(d[0]).join()}, uVertexBasePosition(v1)=${m(d[1]).join()}, uTranslation=${r.join()}`)}}function i2(i,e,t,n,s,r){const o=[];for(let a=0;a<6;++a){const l=kv(i,e,t,n,s,r,a,!1);l!==void 0&&o.push(l)}return o}function JI(i,e,t){const{gl:n}=i;n.uniform3fv(i.uniform("uPlaneNormal"),e),n.uniform1f(i.uniform("uPlaneDistance"),t);const s=Lv(e);n.uniform2iv(i.uniform("uVertexIndex"),Rv.subarray(s*48,(s+1)*48))}function zd(i,e,t,n,s){const r=(0,C.uD)(WI,e,n);C.eR.normalize(r,r);const o=C.eR.dot(C.eR.transformMat4(HI,t,s),r);JI(i,r,o)}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Wd=!1,Pv=.001,Av=C.pB.create();function jI(i,e){if(xi(i),Va(i),i.addUniform("highp vec3","uTranslation"),i.addUniform("highp mat4","uProjectionMatrix"),i.addUniform("highp vec3","uChunkDataSize"),i.addUniform("highp vec3","uLowerClipBound"),i.addUniform("highp vec3","uUpperClipBound"),e){In(i),i.setVertexMain(` +int vertexIndex1 = gl_VertexID / ${Ut}; +int vertexIndex2 = vertexIndex1 == 5 ? 0 : vertexIndex1 + 1; +vec3 vertexPosition1 = getBoundingBoxPlaneIntersectionVertexPosition(uChunkDataSize, uTranslation, uLowerClipBound, uUpperClipBound, vertexIndex1); +vec3 vertexPosition2 = getBoundingBoxPlaneIntersectionVertexPosition(uChunkDataSize, uTranslation, uLowerClipBound, uUpperClipBound, vertexIndex2); +emitLine(uProjectionMatrix * vec4(vertexPosition1, 1.0), + uProjectionMatrix * vec4(vertexPosition2, 1.0), + 2.0); +`),i.setFragmentMain(` +emit(vec4(1.0, 1.0, 1.0, getLineAlpha())); +`);return}i.addVarying("highp vec3","vChunkPosition"),i.setVertexMain(` +vec3 position = getBoundingBoxPlaneIntersectionVertexPosition(uChunkDataSize, uTranslation, uLowerClipBound, uUpperClipBound, gl_VertexID); +gl_Position = uProjectionMatrix * vec4(position, 1.0); +gl_Position.z = 0.0; +vChunkPosition = (position - uTranslation) + + ${Pv} * abs(uPlaneNormal); +`)}function YI(i,e,t,n,s,r,o){const a=C.eR.create(),l=C.eR.create(),c=C.eR.fromValues(Math.abs(s[0]),Math.abs(s[1]),Math.abs(s[2])),d=C.eR.create();for(let u=0;u<6;++u){const h=kv(i,e,t,n,s,r,u);if(h===void 0){console.log("no intersection found");return}C.eR.transformMat4(a,h,o);const p=u!==0&&C.eR.equals(a,d);C.eR.copy(d,a),C.eR.sub(l,h,r),C.eR.scaleAndAdd(l,l,c,Pv),console.log(`${p?"SKIPPED":"OUTPUT"} vertex ${u}, at ${a}, vChunkPosition = ${l}, uTranslation=${r.join()}, position=${h.join()}`)}}function QI(i,e,t){t&&vn(i,e,1)}function KI(i,e,t,n,s,r){const o=t.projectionParameters.value,{centerDataPosition:a}=o;zd(e,o.viewportNormalInGlobalCoordinates,a,r.transform,r.invTransform),i.uniformMatrix4fv(e.uniform("uProjectionMatrix"),!1,C.pB.multiply(Av,n,r.transform)),i.uniform3fv(e.uniform("uLowerClipBound"),s.lowerClipDisplayBound),i.uniform3fv(e.uniform("uUpperClipBound"),s.upperClipDisplayBound),Wd&&(window.debug_sliceView_uLowerClipBound=s.lowerClipDisplayBound,window.debug_sliceView_uUpperClipBound=s.upperClipDisplayBound,window.debug_sliceView=t,window.debug_sliceView_dataToDevice=C.pB.clone(Av),window.debug_sliceView_chunkLayout=r)}function qI(i,e,t){i.uniform3fv(e.uniform("uChunkDataSize"),t),Wd&&(window.debug_sliceView_chunkDataSize=t)}function XI(i,e,t,n){if(i.uniform3fv(e.uniform("uTranslation"),t),n?mn(e.gl,6,1):i.drawArrays(i.TRIANGLE_FAN,0,6),Wd){const r=window.debug_sliceView.projectionParameters.value,o=window.debug_sliceView_chunkDataSize,a=window.debug_sliceView_uLowerClipBound,l=window.debug_sliceView_uUpperClipBound,c=window.debug_sliceView_dataToDevice,d=window.debug_sliceView_chunkLayout;console.log(`Drawing chunk: ${t.join()} of data size ${o.join()}, projection`,c);const u=d.globalToLocalNormal(C.eR.create(),r.viewportNormalInGlobalCoordinates),h=C.eR.dot(C.eR.transformMat4(C.eR.create(),r.centerDataPosition,d.invTransform),u);YI(o,a,l,h,u,t,c)}}function ZI(i,e,t){return i>e?t>i?i:e>t?e:t:t>e?e:i>t?i:t}class Mv extends Fc{constructor(e,t){const{shaderError:n=dr(),shaderParameters:s}=t;super(e.chunkManager,e,t);const{gl:r}=this;this.vertexIdHelper=this.registerDisposer(Qn.get(r)),this.shaderParameters=s;const{channelCoordinateSpace:o}=t;this.channelCoordinateSpace=o===void 0?(0,_.XZ)(Fn):o,this.registerDisposer(s.changed.add(this.redrawNeeded.dispatch));const a=this.registerDisposer((0,_.Uq)((l,c)=>({numChannelDimensions:l.rank,dataHistogramChannelSpecifications:c}),[this.channelCoordinateSpace,this.dataHistogramSpecifications.channels]));this.shaderGetter=wo(this,r,{memoizeKey:`volume/RenderLayer:${xt(this.constructor)}`,fallbackParameters:t.fallbackShaderParameters,parameters:s,encodeParameters:t.encodeShaderParameters,shaderError:n,extraParameters:a,defineShader:(l,c,d,u)=>{const{chunkFormat:h,dataHistogramsEnabled:p}=c,{dataHistogramChannelSpecifications:m,numChannelDimensions:g}=u;if(jI(l,h===null),l.addOutputBuffer("vec4","v4f_fragData0",0),l.addFragmentCode(` +void emit(vec4 color) { + v4f_fragData0 = color; +} +`),h===null)return;Ev(l,h,g,"vChunkPosition");const v=m.length;if(p&&v>0){let y="";const{dataType:S}=h;for(let w=0;w 1.0) x = 1.0; +else x = (1.0 + x * 253.0) / 255.0; +${x} = vec4(x, x, x, 1.0); +}`}l.addFragmentCode(`void userMain(); +void main() { + ${y} + userMain(); +} +#define main userMain +`)}this.defineShader(l,d)},getContextKey:l=>`${l.chunkFormat?.shaderKey}/${l.dataHistogramsEnabled}`}),this.tempChunkPosition=new Float32Array(e.rank),this.initializeCounterpart()}get dataType(){return this.multiscaleSource.dataType}getValueAt(e){const{tempChunkPosition:t}=this;for(const{source:n,chunkTransform:s}of this.visibleSourcesList){if(!gs(t,e,this.localPosition.value,s.layerRank,s.combinedGlobalLocalToChunkTransform))continue;const r=n.getValueAt(t,s);if(r!=null)return r}return null}beginChunkFormat(e,t,n){const{gl:s}=this,r=this.dataHistogramSpecifications.visibility.visible,o=this.shaderGetter({chunkFormat:t,dataHistogramsEnabled:r}),{shader:a,parameters:l,fallback:c}=o;if(a!==null&&(a.bind(),QI(a,n,t===null),t!==null)){if(r){const{dataHistogramChannelSpecifications:d}=o.extraParameters,u=d.length,h=this.dataHistogramSpecifications.bounds.value;for(let p=0;p{u!==null&&(u.unbindTransferFunctionTextures(),h!==null&&h.endDrawing(a,u),this.endSlice(t,u,d.parameters))};let g=!0;for(const v of s){const y=Mc(r,v.chunkLayout),{chunkTransform:{channelToChunkDimensionIndices:S}}=v,w=v.source,{fixedPositionWithinChunk:b,chunkDisplayDimensionIndices:x}=v;for(const V of x)b[V]=0;const E=o?null:w.chunkFormat;if(E!==h&&(h=E,m(),d=this.beginChunkFormat(t,E,r),u=d.shader),u===null)continue;const D=w.chunks;p.fill(1);const I=y.size;let L;const N=w.spec.rank;KI(a,u,t,r.viewProjectionMat,v,y),E!==null&&E.beginSource(a,u),g=!0;let k=0,O=0;if(t.forEachVisibleChunk(v,y,V=>{const z=D.get(V);if(z&&z.state===Ue.GPU_MEMORY){const Y=z.chunkDataSize;if(Y!==L){L=Y;for(let X=0;X<3;++X){const ce=x[X];p[X]=ce===-1||ce>=N?1:L[ce]}qI(a,u,p)}const{chunkGridPosition:Q}=z;for(let X=0;X<3;++X){const ce=x[X];l[X]=ce===-1||ce>=N?0:I[X]*Q[ce]}E!==null&&E.bindChunk(a,u,z,b,x,S,g),g=!1,XI(a,u,l,o),++k}else++O}),(k!==0||O!==0)&&c!==void 0){const{effectiveVoxelSize:V}=v,z=ZI(V[0],V[1],V[2]);c.add(z,z/r.pixelSize,k,O)}}if(m(),this.vertexIdHelper.disable(),!e.wireFrame){const v=this.getDataHistogramCount();v>0&&t.computeHistograms(v,this.dataHistogramSpecifications)}}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Nv{constructor(e){this.disjointSets=e,this.generation=Number.NaN,this.hashMap=new yd}update(){const{disjointSets:e}=this,{generation:t}=e;if(this.generation!==t){this.generation=t;const{hashMap:n}=this;n.clear();for(const[s,r]of e.mappings())n.set(s,r)}}}const Ov=1,_v=2;class Vv extends Mv{constructor(e,t){super(e,{shaderParameters:new _.wP(n=>({hasEquivalences:n.registerDisposer((0,_.Uq)(s=>s.size!==0,[t.segmentationGroupState.value.segmentEquivalences])),hasSegmentStatedColors:n.registerDisposer((0,_.Uq)((s,r,o)=>(o?r:s).size!==0,[t.segmentStatedColors,t.tempSegmentStatedColors2d,t.useTempSegmentStatedColors2d])),hasSegmentDefaultColor:n.registerDisposer((0,_.Uq)((s,r)=>s!==void 0||r!==void 0,[t.segmentDefaultColor,t.tempSegmentDefaultColor2d])),hasHighlightColor:n.registerDisposer((0,_.Uq)(s=>s!==void 0,[t.highlightColor])),hideSegmentZero:t.hideSegmentZero,baseSegmentColoring:t.baseSegmentColoring,baseSegmentHighlighting:t.baseSegmentHighlighting})),transform:t.transform,renderScaleHistogram:t.renderScaleHistogram,renderScaleTarget:t.renderScaleTarget,localPosition:t.localPosition}),this.displayState=t,this.segmentationGroupState=this.displayState.segmentationGroupState.value,this.segmentColorShaderManager=new ED("segmentColorHash"),this.segmentStatedColorShaderManager=new TD("segmentStatedColor"),this.hashTableManager=new wm("visibleSegments"),this.gpuHashTable=this.registerDisposer(Hi.get(this.gl,this.segmentationGroupState.visibleSegments.hashTable)),this.gpuTemporaryHashTable=Hi.get(this.gl,this.segmentationGroupState.temporaryVisibleSegments.hashTable),this.equivalencesShaderManager=new xm("equivalences"),this.equivalencesHashMap=new Nv(this.segmentationGroupState.segmentEquivalences.disjointSets),this.temporaryEquivalencesHashMap=new Nv(this.segmentationGroupState.temporarySegmentEquivalences.disjointSets),this.gpuEquivalencesHashTable=this.registerDisposer(Hi.get(this.gl,this.equivalencesHashMap.hashMap)),this.gpuTemporaryEquivalencesHashTable=this.registerDisposer(Hi.get(this.gl,this.temporaryEquivalencesHashMap.hashMap)),this.registerDisposer(this.shaderParameters),Hm(t,this),this.registerDisposer(t.selectedAlpha.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(t.notSelectedAlpha.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(t.ignoreNullVisibleSet.changed.add(this.redrawNeeded.dispatch))}disposed(){this.gpuSegmentStatedColorHashTable?.dispose()}getSources(e){return this.multiscaleSource.getSources({...e,discreteValues:!0})}defineShader(e,t){this.hashTableManager.defineShader(e);let n=` +uint64_t getUint64DataValue() { + uint64_t x = toUint64(getDataValue()); +`;n+=`return x; +} +`,e.addFragmentCode(n),t.hasEquivalences?(this.equivalencesShaderManager.defineShader(e),e.addFragmentCode(` +uint64_t getMappedObjectId(uint64_t value) { + uint64_t mappedValue; + if (${this.equivalencesShaderManager.getFunctionName}(value, mappedValue)) { + return mappedValue; + } + return value; +} +`)):e.addFragmentCode(` +uint64_t getMappedObjectId(uint64_t value) { + return value; +} +`),e.addUniform("highp uvec2","uSelectedSegment"),e.addUniform("highp uint","uFlags"),e.addUniform("highp float","uSelectedAlpha"),e.addUniform("highp float","uNotSelectedAlpha"),e.addUniform("highp float","uSaturation");let s=` + uint64_t baseValue = getUint64DataValue(); + uint64_t value = getMappedObjectId(baseValue); + uint64_t valueForColor = ${t.baseSegmentColoring?"baseValue":"value"}; + uint64_t valueForHighlight = ${t.baseSegmentHighlighting?"baseValue":"value"}; + + float alpha = uSelectedAlpha; + float saturation = uSaturation; +`;t.hideSegmentZero&&(s+=` + if (value.value[0] == 0u && value.value[1] == 0u) { + emit(vec4(vec4(0, 0, 0, 0))); + return; + } +`),s+=` + bool has = (uFlags & ${_v}u) != 0u ? true : ${this.hashTableManager.hasFunctionName}(value); + if ((uFlags & ${Ov}u) != 0u && uSelectedSegment == valueForHighlight.value) { + float adjustment = has ? 0.5 : 0.75; + if (saturation > adjustment) { + saturation -= adjustment; + } else { + saturation += adjustment; + } +`,t.hasHighlightColor&&(e.addUniform("highp vec4","uHighlightColor"),s+=` + emit(uHighlightColor); + return; +`),s+=` + } else if (!has) { + alpha = uNotSelectedAlpha; + } +`;let r=`vec4 getMappedIdColor(uint64_t value) { +`;t.hasSegmentStatedColors&&(this.segmentStatedColorShaderManager.defineShader(e),r+=` + vec4 rgba; + if (${this.segmentStatedColorShaderManager.getFunctionName}(value, rgba)) { + return rgba; + } +`),t.hasSegmentDefaultColor?(e.addUniform("highp vec4","uSegmentDefaultColor"),r+=` return uSegmentDefaultColor; +`):(this.segmentColorShaderManager.defineShader(e),r+=` return vec4(segmentColorHash(value), 0.0); +`),r+=` +} +`,e.addFragmentCode(r),s+=` + vec4 rgba = getMappedIdColor(valueForColor); + if (rgba.a > 0.0) { + alpha = rgba.a; + } + emit(vec4(mix(vec3(1.0,1.0,1.0), vec3(rgba), saturation), alpha)); +`,e.setFragmentMain(s)}initializeShader(e,t,n){const{gl:s}=this,{displayState:r,segmentationGroupState:o}=this,{segmentSelectionState:a}=this.displayState,{segmentDefaultColor:{value:l},segmentColorHash:{value:c},highlightColor:{value:d},tempSegmentDefaultColor2d:{value:u}}=this.displayState,h=dg(o),p=this.displayState.ignoreNullVisibleSet.value;let m=0,g=0,v=0;if(a.hasSelectedSegment&&r.hoverHighlight.value){const S=r.baseSegmentHighlighting.value?a.baseSelectedSegment:a.selectedSegment;m=S.low,g=S.high,v|=Ov}if(s.uniform1f(t.uniform("uSelectedAlpha"),r.selectedAlpha.value),s.uniform1f(t.uniform("uSaturation"),r.saturation.value),s.uniform1f(t.uniform("uNotSelectedAlpha"),r.notSelectedAlpha.value),s.uniform2ui(t.uniform("uSelectedSegment"),m,g),h.hashTable.size===0&&p&&(v|=_v),s.uniform1ui(t.uniform("uFlags"),v),this.hashTableManager.enable(s,t,o.useTemporaryVisibleSegments.value?this.gpuTemporaryHashTable:this.gpuHashTable),n.hasEquivalences){const S=o.useTemporarySegmentEquivalences.value;(S?this.temporaryEquivalencesHashMap:this.equivalencesHashMap).update(),this.equivalencesShaderManager.enable(s,t,S?this.gpuTemporaryEquivalencesHashTable:this.gpuEquivalencesHashTable)}const y=u||l;if(y){const[S,w,b,x]=y;s.uniform4f(t.uniform("uSegmentDefaultColor"),S,w,b,x===void 0?0:x)}else this.segmentColorShaderManager.enable(s,t,c);if(n.hasSegmentStatedColors){const S=r.useTempSegmentStatedColors2d.value?r.tempSegmentStatedColors2d.value:r.segmentStatedColors.value;let{gpuSegmentStatedColorHashTable:w}=this;(w===void 0||w.hashTable!==S.hashTable)&&(w?.dispose(),this.gpuSegmentStatedColorHashTable=w=Hi.get(s,S.hashTable)),this.segmentStatedColorShaderManager.enable(s,t,w)}d!==void 0&&s.uniform4fv(t.uniform("uHighlightColor"),d)}endSlice(e,t,n){const{gl:s}=this;this.hashTableManager.disable(s,t),n.hasEquivalences&&this.equivalencesShaderManager.disable(s,t),n.hasSegmentStatedColors&&this.segmentStatedColorShaderManager.disable(s,t),super.endSlice(e,t,n)}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function zr(i=.5){return new _.DN(i,f.xU)}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Hd=12,Bv=8,eL=6,tL=` +vec3 getBoxFaceVertexPosition(int vertexIndex) { + const vec3 vertexPositions[] = vec3[]( + // Front face + vec3(0.0, 0.0, 1.0), // 0 + vec3(1.0, 0.0, 1.0), // 1 + vec3(1.0, 1.0, 1.0), // 2 + vec3(0.0, 1.0, 1.0), // 3 + + // Back face + vec3(0.0, 0.0, 0.0), // 4 + vec3(0.0, 1.0, 0.0), // 5 + vec3(1.0, 1.0, 0.0), // 6 + vec3(1.0, 0.0, 0.0), // 7 + + // Top face + vec3(0.0, 1.0, 0.0), // 8 + vec3(0.0, 1.0, 1.0), // 9 + vec3(1.0, 1.0, 1.0), // 10 + vec3(1.0, 1.0, 0.0), // 11 + + // Bottom face + vec3(0.0, 0.0, 0.0), // 12 + vec3( 1.0, 0.0, 0.0), // 13 + vec3( 1.0, 0.0, 1.0), // 14 + vec3(0.0, 0.0, 1.0), // 15 + + // Right face + vec3( 1.0, 0.0, 0.0), // 16 + vec3( 1.0, 1.0, 0.0), // 17 + vec3( 1.0, 1.0, 1.0), // 18 + vec3( 1.0, 0.0, 1.0), // 19 + + // Left face + vec3(0.0, 0.0, 0.0), // 20 + vec3(0.0, 0.0, 1.0), // 21 + vec3(0.0, 1.0, 1.0), // 22 + vec3(0.0, 1.0, 0.0) // 23 + ); + const int indices[] = int[]( + 0, 1, 2, 0, 2, 3, // front + 4, 5, 6, 4, 6, 7, // back + 8, 9, 10, 8, 10, 11, // top + 12, 13, 14, 12, 14, 15, // bottom + 16, 17, 18, 16, 18, 19, // right + 20, 21, 22, 20, 22, 23 // left + ); + return vertexPositions[indices[vertexIndex]]; +} +`;function Fv(i,e,t){i.drawArraysInstanced(WebGL2RenderingContext.TRIANGLES,0,6*eL*e,t)}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Uv=0,Ba=Uv+1,Pt=Ba+Bv,Jd=Pt+Hd,nL=Jd+6,iL=Float32Array.from([0,0,0,0,0,1,Pt+0,1,0,0,1,0,1,Pt+1,0,1,0,0,1,1,Pt+2,1,1,0,1,1,1,Pt+3,0,0,0,0,1,0,Pt+4,0,0,1,0,1,1,Pt+5,1,0,0,1,1,0,Pt+6,1,0,1,1,1,1,Pt+7,0,0,0,1,0,0,Pt+8,0,0,1,1,0,1,Pt+9,0,1,0,1,1,0,Pt+10,0,1,1,1,1,1,Pt+11]),$v=C.pB.create(),Ei=new Float32Array(6);class Gv extends qo{constructor(){super(...arguments),this.vertexIdHelper=this.registerDisposer(Qn.get(this.gl))}defineShader(e){xi(e);const{rank:t}=this;Do(e,"float",WebGL2RenderingContext.FLOAT,!1,"Bounds",t,2),e.addUniform("vec3","uModelSpaceBoundOffsets",2)}enable(e,t,n){C.pB.invert($v,t.modelViewProjectionMatrix),(0,C.bS)($v,Ei);const{numChunkDisplayDims:s}=t.chunkDisplayTransform;for(let r=0;r{const o=r.vertexShaderInputBinders.Bounds;o.enable(1);const{gl:a}=this;a.uniform3fv(r.uniform("uModelSpaceBoundOffsets"),Ei),a.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER,t.buffer.buffer),o.bind(this.geometryDataStride,t.bufferOffset);const{vertexIdHelper:l}=this;l.enable(),n(r),l.disable(),o.disable()})}}function zv(i){i.addVertexCode(` +void setBoundingBoxBorderWidth(float width) {} +void setBoundingBoxBorderColor(vec4 color) {} +`)}function Wv(i){i.addVertexCode(` +void setBoundingBoxFillColor(vec4 color) {} +`)}function jd(i){Wv(i),i.addVertexCode(` +float ng_lineWidth; +void setBoundingBoxBorderWidth(float size) { + ng_lineWidth = size; +} +void setBoundingBoxBorderColor(vec4 color) { + vColor = color; +} +`)}function sL(i){zv(i),i.addVertexCode(` +void setBoundingBoxFillColor(vec4 color) { + vColor = color; +} +`)}class rL extends Gv{constructor(){super(...arguments),this.edgeBoxCornerOffsetsBuffer=this.registerDisposer(At.fromData(this.gl,(0,F.CS)(iL,7,1,Ut))),this.edgeShaderGetter=this.getDependentShader("annotation/boundingBox/projection/border",e=>{const{rank:t}=this;this.defineShader(e),In(e),e.addAttribute("highp vec3","aBoxCornerOffset1"),e.addAttribute("highp vec4","aBoxCornerOffset2"),e.addVarying("highp float","vClipCoefficient"),jd(e),e.setVertexMain(` +float modelPositionA[${t}] = getBounds0(); +float modelPositionB[${t}] = getBounds1(); +vec3 subspacePositionA = projectModelVectorToSubspace(modelPositionA) + uModelSpaceBoundOffsets[0]; +vec3 subspacePositionB = projectModelVectorToSubspace(modelPositionB) + uModelSpaceBoundOffsets[1]; +vec3 endpointA = mix(subspacePositionA, subspacePositionB, aBoxCornerOffset1); +vec3 endpointB = mix(subspacePositionA, subspacePositionB, aBoxCornerOffset2.xyz); +vClipCoefficient = getMaxSubspaceClipCoefficient(modelPositionA, modelPositionB); +if (vClipCoefficient == 0.0) { + gl_Position = vec4(2.0, 0.0, 0.0, 1.0); + return; +} +ng_lineWidth = 1.0; +${this.invokeUserMain} +emitLine(uModelViewProjection * vec4(endpointA, 1.0), + uModelViewProjection * vec4(endpointB, 1.0), + ng_lineWidth); +${this.setPartIndex(e,"uint(aBoxCornerOffset2.w)")}; +`),e.setFragmentMain(` +emitAnnotation(vec4(vColor.rgb, getLineAlpha() * vClipCoefficient)); +`)}),this.boxCornerOffsetsBuffer=this.registerDisposer(At.fromData(this.gl,(0,F.CS)(Gd,3,1,mv))),this.cornerShaderGetter=this.getDependentShader("annotation/boundingBox/projection/corner",e=>{const{rank:t}=this;this.defineShader(e),Aa(e,this.targetIsSliceView),e.addAttribute("highp vec3","aBoxCornerOffset"),e.addVarying("highp float","vClipCoefficient"),jd(e),e.setVertexMain(` +float modelPositionA[${t}] = getBounds0(); +float modelPositionB[${t}] = getBounds1(); +vClipCoefficient = getMaxEndpointSubspaceClipCoefficient(modelPositionA, modelPositionB); +if (vClipCoefficient == 0.0) { + gl_Position = vec4(2.0, 0.0, 0.0, 1.0); + return; +} +vec3 subspacePositionA = projectModelVectorToSubspace(modelPositionA) + uModelSpaceBoundOffsets[0]; +vec3 subspacePositionB = projectModelVectorToSubspace(modelPositionB) + uModelSpaceBoundOffsets[1]; +vec3 vertexPosition = mix(subspacePositionA, subspacePositionB, aBoxCornerOffset); +emitCircle(uModelViewProjection * vec4(vertexPosition, 1.0), ng_lineWidth, 0.0); +uint cornerIndex = uint(aBoxCornerOffset.x + aBoxCornerOffset.y * 2.0 + aBoxCornerOffset.z * 4.0); +uint cornerPickOffset = ${Ba}u + cornerIndex; +${this.setPartIndex(e,"cornerPickOffset")}; +`),e.setFragmentMain(` +vec4 borderColor = vec4(0.0, 0.0, 0.0, 1.0); +vec4 color = getCircleColor(vColor, borderColor); +color.a *= vClipCoefficient; +emitAnnotation(color); +`)})}drawEdges(e){const{gl:t}=this;this.enable(this.edgeShaderGetter,e,n=>{const s=n.attribute("aBoxCornerOffset1"),r=n.attribute("aBoxCornerOffset2");this.edgeBoxCornerOffsetsBuffer.bindToVertexAttrib(s,3,WebGL2RenderingContext.FLOAT,!1,28,0),this.edgeBoxCornerOffsetsBuffer.bindToVertexAttrib(r,4,WebGL2RenderingContext.FLOAT,!1,28,12),vn(n,e.renderContext.projectionParameters,1),mn(t,Hd,e.count),t.disableVertexAttribArray(s),t.disableVertexAttribArray(r)})}drawCorners(e){const{gl:t}=this;this.enable(this.cornerShaderGetter,e,n=>{const s=n.attribute("aBoxCornerOffset");this.boxCornerOffsetsBuffer.bindToVertexAttrib(s,3,WebGL2RenderingContext.FLOAT,!1),Ma(n,e.renderContext.projectionParameters,{featherWidthInPixels:0}),Na(n.gl,Bv,e.count),t.disableVertexAttribArray(s)})}draw(e){this.drawEdges(e),this.drawCorners(e)}}class oL extends Gv{constructor(){super(...arguments),this.faceShaderGetter=this.getDependentShader("annotation/boundingBox/crossSection/face",e=>{const{rank:t}=this;super.defineShader(e),Va(e),In(e),e.addVarying("highp float","vClipCoefficient"),jd(e),e.setVertexMain(` +float modelPositionA[${t}] = getBounds0(); +float modelPositionB[${t}] = getBounds1(); +for (int i = 0; i < ${t}; ++i) { + float a = modelPositionA[i]; + float b = modelPositionB[i]; + modelPositionA[i] = min(a, b); + modelPositionB[i] = max(a, b); +} +vClipCoefficient = getMaxSubspaceClipCoefficient(modelPositionA, modelPositionB); +if (vClipCoefficient == 0.0) { + gl_Position = vec4(2.0, 0.0, 0.0, 1.0); + return; +} +vec3 subspacePositionA = projectModelVectorToSubspace(modelPositionA) + uModelSpaceBoundOffsets[0]; +vec3 subspacePositionB = projectModelVectorToSubspace(modelPositionB) + uModelSpaceBoundOffsets[1]; +int vertexIndex1 = gl_VertexID / ${Ut}; +int vertexIndex2 = vertexIndex1 == 5 ? 0 : vertexIndex1 + 1; +vec3 vertexPosition1 = getBoundingBoxPlaneIntersectionVertexPosition(subspacePositionB - subspacePositionA, subspacePositionA, subspacePositionA, subspacePositionB, vertexIndex1); +vec3 vertexPosition2 = getBoundingBoxPlaneIntersectionVertexPosition(subspacePositionB - subspacePositionA, subspacePositionA, subspacePositionA, subspacePositionB, vertexIndex2); +ng_lineWidth = 1.0; +${this.invokeUserMain} +emitLine(uModelViewProjection * vec4(vertexPosition1, 1.0), + uModelViewProjection * vec4(vertexPosition2, 1.0), + ng_lineWidth); +${this.setPartIndex(e)}; +`),e.setFragmentMain(` +emitAnnotation(vec4(vColor.rgb, vColor.a * getLineAlpha() * vClipCoefficient)); +`)}),this.fillShaderGetter=this.getDependentShader("annotation/boundingBox/crossSection/fill",e=>{const{rank:t}=this;super.defineShader(e),Va(e),e.addVarying("highp float","vClipCoefficient"),sL(e),e.setVertexMain(` +float modelPositionA[${t}] = getBounds0(); +float modelPositionB[${t}] = getBounds1(); +for (int i = 0; i < ${t}; ++i) { + float a = modelPositionA[i]; + float b = modelPositionB[i]; + modelPositionA[i] = min(a, b); + modelPositionB[i] = max(a, b); +} +vClipCoefficient = getMaxSubspaceClipCoefficient(modelPositionA, modelPositionB); +if (vClipCoefficient == 0.0) { + gl_Position = vec4(2.0, 0.0, 0.0, 1.0); + return; +} +vec3 subspacePositionA = projectModelVectorToSubspace(modelPositionA) + uModelSpaceBoundOffsets[0]; +vec3 subspacePositionB = projectModelVectorToSubspace(modelPositionB) + uModelSpaceBoundOffsets[1]; +int vertexIndex = gl_VertexID; +vec3 vertexPosition = getBoundingBoxPlaneIntersectionVertexPosition(subspacePositionB - subspacePositionA, subspacePositionA, subspacePositionA, subspacePositionB, vertexIndex); +gl_Position = uModelViewProjection * vec4(vertexPosition, 1); +${this.invokeUserMain} +${this.setPartIndex(e)}; +`),e.setFragmentMain(` +emitAnnotation(vec4(vColor.rgb, vColor.a * vClipCoefficient)); +`)})}enableForBoundingBox(e,t,n){super.enable(e,t,s=>{const r=t.renderContext.sliceView.projectionParameters.value;zd(s,r.viewportNormalInGlobalCoordinates,r.centerDataPosition,t.renderSubspaceModelMatrix,t.renderSubspaceInvModelMatrix),n(s)})}draw(e){this.shaderControlState.parseResult.value.code.match(/\bsetBoundingBoxFillColor\b/)&&this.enableForBoundingBox(this.fillShaderGetter,e,()=>{pw(this.gl,WebGL2RenderingContext.TRIANGLE_FAN,0,6,e.count)}),this.enableForBoundingBox(this.faceShaderGetter,e,t=>{vn(t,e.renderContext.projectionParameters,1),mn(t.gl,6,e.count)})}}function aL(i,e){const t=i.length;for(let n=0;n=Ba&&n=Pt&&n=Ba&&t=Pt&&t{const{rank:t}=this;this.defineShader(e),In(e),e.addVarying(`highp float[${t}]`,"vModelPosition"),e.addVertexCode(` +float ng_LineWidth; +`),Hv(e),e.addVertexCode(` +void setLineWidth(float width) { + ng_LineWidth = width; +} +void setLineColor(vec4 startColor, vec4 endColor) { + vColor = mix(startColor, endColor, getLineEndpointCoefficient()); +} +`),e.setVertexMain(` +float modelPositionA[${t}] = getVertexPosition0(); +float modelPositionB[${t}] = getVertexPosition1(); +for (int i = 0; i < ${t}; ++i) { + vModelPosition[i] = mix(modelPositionA[i], modelPositionB[i], getLineEndpointCoefficient()); +} +ng_LineWidth = 1.0; +vColor = vec4(0.0, 0.0, 0.0, 0.0); +${this.invokeUserMain} +emitLine(uModelViewProjection * vec4(projectModelVectorToSubspace(modelPositionA), 1.0), + uModelViewProjection * vec4(projectModelVectorToSubspace(modelPositionB), 1.0), + ng_LineWidth); +${this.setPartIndex(e)}; +`),e.setFragmentMain(` +float clipCoefficient = getSubspaceClipCoefficient(vModelPosition); +emitAnnotation(vec4(vColor.rgb, vColor.a * getLineAlpha() * + ${this.getCrossSectionFadeFactor()} * + clipCoefficient)); +`)}),this.endpointShaderGetter=this.getDependentShader("annotation/line/endpoint",e=>{const{rank:t}=this;this.defineShader(e),Aa(e,this.targetIsSliceView),e.addVarying("highp float","vClipCoefficient"),e.addVarying("highp vec4","vBorderColor"),Jv(e),e.addVertexCode(` +float ng_markerDiameter; +float ng_markerBorderWidth; +int getEndpointIndex() { + return gl_VertexID / ${mv}; +} +void setEndpointMarkerSize(float startSize, float endSize) { + ng_markerDiameter = mix(startSize, endSize, float(getEndpointIndex())); +} +void setEndpointMarkerBorderWidth(float startSize, float endSize) { + ng_markerBorderWidth = mix(startSize, endSize, float(getEndpointIndex())); +} +void setEndpointMarkerColor(vec4 startColor, vec4 endColor) { + vColor = mix(startColor, endColor, float(getEndpointIndex())); +} +void setEndpointMarkerBorderColor(vec4 startColor, vec4 endColor) { + vBorderColor = mix(startColor, endColor, float(getEndpointIndex())); +} +`),e.setVertexMain(` +float modelPosition[${t}] = getVertexPosition0(); +float modelPositionB[${t}] = getVertexPosition1(); +for (int i = 0; i < ${t}; ++i) { + modelPosition[i] = mix(modelPosition[i], modelPositionB[i], float(getEndpointIndex())); +} +vClipCoefficient = getSubspaceClipCoefficient(modelPosition); +vColor = vec4(0.0, 0.0, 0.0, 0.0); +vBorderColor = vec4(0.0, 0.0, 0.0, 1.0); +ng_markerDiameter = 5.0; +ng_markerBorderWidth = 1.0; +${this.invokeUserMain} +emitCircle(uModelViewProjection * vec4(projectModelVectorToSubspace(modelPosition), 1.0), ng_markerDiameter, ng_markerBorderWidth); +${this.setPartIndex(e,"uint(getEndpointIndex()) + 1u")}; +`),e.setFragmentMain(` +vec4 color = getCircleColor(vColor, vBorderColor); +color.a *= vClipCoefficient; +emitAnnotation(color); +`)})}defineShader(e){xi(e);const{rank:t}=this;Do(e,"float",WebGL2RenderingContext.FLOAT,!1,"VertexPosition",t,2)}enable(e,t,n){super.enable(e,t,s=>{const r=s.vertexShaderInputBinders.VertexPosition;r.enable(1),this.gl.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER,t.buffer.buffer),r.bind(this.geometryDataStride,t.bufferOffset);const{vertexIdHelper:o}=this;o.enable(),n(s),o.disable(),r.disable()})}drawEdges(e){this.enable(this.edgeShaderGetter,e,t=>{vn(t,e.renderContext.projectionParameters,1),mn(t.gl,1,e.count)})}drawEndpoints(e){this.enable(this.endpointShaderGetter,e,t=>{Ma(t,e.renderContext.projectionParameters,{featherWidthInPixels:.5}),Na(t.gl,2,e.count)})}draw(e){this.drawEdges(e),this.drawEndpoints(e)}}function cL(i,e){const t=i.length;(0,C._q)(i,e.subarray(0,t),e.subarray(t),i)}function dL(i,e,t){const n=i.length,s=n*t;for(let r=0;r{xi(e),Aa(e,this.targetIsSliceView),this.defineShaderCommon(e),e.addVertexMain(` +emitCircle(uModelViewProjection * + vec4(projectModelVectorToSubspace(modelPosition), 1.0), ng_markerDiameter, ng_markerBorderWidth); +`),e.setFragmentMain(` +vec4 color = getCircleColor(vColor, vBorderColor); +emitAnnotation(color); +`)}),this.makeShaderGetter2d=e=>this.getDependentShader(`annotation/point:2d:${e}`,t=>{xi(t),In(t,!0),this.defineShaderCommon(t),t.addVertexMain(` +vec3 subspacePositionA = projectModelVectorToSubspace(modelPosition); +vec3 subspacePositionB = subspacePositionA; +vec4 baseProjection = uModelViewProjection * vec4(subspacePositionA, 1.0); +vec4 zCoeffs = uModelViewProjection[${e}]; +float minZ = 1e30; +float maxZ = -1e30; +for (int i = 0; i < 3; ++i) { + // Want: baseProjection[i] + z * zCoeffs[i] = -2.0 * (baseProjection.w - z * zCoeffs.w) + // i.e. baseProjection[i] + 2.0 * baseProjection.w < -z * (2.0 * zCoeffs.w + zCoeffs[i]) + // i.e. baseProjection[i] + 2.0 * baseProjection.w < -z * k1 + float k1 = 2.0 * zCoeffs.w + zCoeffs[i]; + float q1 = -(baseProjection[i] + 2.0 * baseProjection.w) / k1; + if (k1 != 0.0) { + minZ = min(minZ, q1); + maxZ = max(maxZ, q1); + } + // Want: baseProjection[i] + z * zCoeffs[i] = 2.0 * (baseProjection.w + z * zCoeffs.w) + // i.e. baseProjection[i] - 2.0 * baseProjection.w > z * (2.0 * zCoeffs.w - zCoeffs[i]) + // i.e. baseProjection[i] - 2.0 * baseProjection.w > z * k2 + float k2 = 2.0 * zCoeffs.w - zCoeffs[i]; + float q2 = (baseProjection[i] - 2.0 * baseProjection.w) / k2; + if (k2 != 0.0) { + minZ = min(minZ, q2); + maxZ = max(maxZ, q2); + } +} +if (minZ > maxZ) minZ = maxZ = 0.0; +subspacePositionA[${e}] = minZ; +subspacePositionB[${e}] = maxZ; +emitLine(uModelViewProjection, subspacePositionA, subspacePositionB, ng_markerDiameter, ng_markerBorderWidth); +`),t.setFragmentMain(` +vec4 color = getRoundedLineColor(vColor, vBorderColor); +emitAnnotation(vec4(color.rgb, color.a * ${this.getCrossSectionFadeFactor()})); +`)}),this.shaderGetter2d=this.makeShaderGetter2d(2),this.shaderGetter1d=this.makeShaderGetter2d(1),this.vertexIdHelper=this.registerDisposer(Qn.get(this.gl))}defineShaderCommon(e){const{rank:t}=this;Do(e,"float",WebGL2RenderingContext.FLOAT,!1,"VertexPosition",t),e.addVarying("highp vec4","vBorderColor"),e.addVertexCode(` +float ng_markerDiameter; +float ng_markerBorderWidth; +void setPointMarkerSize(float size) { + ng_markerDiameter = size; +} +void setPointMarkerBorderWidth(float size) { + ng_markerBorderWidth = size; +} +void setPointMarkerColor(vec4 color) { + vColor = color; +} +void setPointMarkerBorderColor(vec4 color) { + vBorderColor = color; +} +`),e.addVertexMain(` +ng_markerDiameter = 5.0; +ng_markerBorderWidth = 1.0; +vBorderColor = vec4(0.0, 0.0, 0.0, 1.0); +float modelPosition[${t}] = getVertexPosition0(); +float clipCoefficient = getSubspaceClipCoefficient(modelPosition); +if (clipCoefficient == 0.0) { + gl_Position = vec4(2.0, 0.0, 0.0, 1.0); + return; +} +${this.invokeUserMain} +vColor.a *= clipCoefficient; +vBorderColor.a *= clipCoefficient; +${this.setPartIndex(e)}; +`)}enable(e,t,n){super.enable(e,t,s=>{const r=s.vertexShaderInputBinders.VertexPosition;r.enable(1),this.gl.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER,t.buffer.buffer),r.bind(this.geometryDataStride,t.bufferOffset);const{vertexIdHelper:o}=this;o.enable(),n(s),o.disable(),r.disable()})}draw(e){const{numChunkDisplayDims:t}=e.chunkDisplayTransform;switch(t){case 3:this.enable(this.shaderGetter3d,e,n=>{Ma(n,e.renderContext.projectionParameters,{featherWidthInPixels:1}),Na(n.gl,1,e.count)});break;case 2:case 1:this.enable(t===2?this.shaderGetter2d:this.shaderGetter1d,e,n=>{vn(n,e.renderContext.projectionParameters,1),mn(n.gl,1,e.count)});break}}}Xo(Re.POINT,{sliceViewRenderHelper:Yv,perspectiveViewRenderHelper:Yv,defineShaderNoOpSetters(i){i.addVertexCode(` +void setPointMarkerSize(float size) {} +void setPointMarkerBorderWidth(float size) {} +void setPointMarkerColor(vec4 color) {} +void setPointMarkerBorderColor(vec4 color) {} +`)},pickIdsPerInstance:1,snapPosition(i,e,t){i.set(new Float32Array(e,t,i.length))},getRepresentativePoint(i,e){i.set(e.point)},updateViaRepresentativePoint(i,e){return{...i,point:new Float32Array(e)}}});/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Qv=` +struct EllipseQuadraticForm { + highp float A; // x*x coefficient + highp float B; // x*y coefficient + highp float C; // y*y coefficient + highp float D; // x coefficient + highp float E; // y coefficient + highp float F; // 1 coefficient +}; +`,uL=[Qv,` +EllipseQuadraticForm computeCrossSectionEllipse(mat3 A, vec3 c) { + EllipseQuadraticForm p; + p.A = A[0][0]; + p.B = A[0][1] + A[1][0]; + p.C = A[1][1]; + p.D = -2.0 * c[0] * A[0][0] - c[1] * (A[0][1] + A[1][0]) + + c[2] * (A[0][2] + A[2][0]); + p.E = -c[0] * (A[0][1] + A[1][0]) - 2.0 * c[1] * A[1][1] + + c[2] * (A[1][2] + A[2][1]); + p.F = c[0] * c[0] * A[0][0] + c[0] * c[1] * (A[0][1] + A[1][0]) - + c[0] * c[2] * (A[0][2] + A[2][0]) + c[1] * c[1] * A[1][1] - + c[1] * c[2] * (A[1][2] + A[2][1]) + c[2] * c[2] * A[2][2] - 1.0; + return p; +} +`];function hL(i,e){const t=[[i[0],i[1],i[2]],[i[3],i[4],i[5]],[i[6],i[7],i[8]]];return{A:t[0][0],B:t[0][1]+t[1][0],C:t[1][1],D:-2*e[0]*t[0][0]-e[1]*(t[0][1]+t[1][0])+e[2]*(t[0][2]+t[2][0]),E:-e[0]*(t[0][1]+t[1][0])-2*e[1]*t[1][1]+e[2]*(t[1][2]+t[2][1]),F:e[0]*e[0]*t[0][0]+e[0]*e[1]*(t[0][1]+t[1][0])-e[0]*e[2]*(t[0][2]+t[2][0])+e[1]*e[1]*t[1][1]-e[1]*e[2]*(t[1][2]+t[2][1])+e[2]*e[2]*t[2][2]-1}}const pL=[Qv,` +struct CenterOrientEllipse { + vec2 k; // center + vec2 u1; // minor axis direction + vec2 u2; // major axis direction + float a; // semimajor axis + float b; // semiminor axis + bool valid; // indicates if the ellipse is valid +}; +`,` +CenterOrientEllipse computeCenterOrientEllipse(EllipseQuadraticForm p) { + CenterOrientEllipse r; + float a11 = p.A; + float a12 = p.B / 2.0; + float a22 = p.C; + float b1 = p.D; + float b2 = p.E; + float c = p.F; + float kdenom = 2.0 * (a12 * a12 - a11 * a22); + float k1 = r.k.x = (a22 * b1 - a12 * b2) / kdenom; + float k2 = r.k.y = (a11 * b2 - a12 * b1) / kdenom; + float mu = 1.0 / (a11 * k1 * k1 + 2.0 * a12 * k1 * k2 + a22 * k2 * k2 - c); + float m11 = mu * a11; + float m12 = mu * a12; + float m22 = mu * a22; + float lambdaTerm1 = m11 + m22; + float lambdaTerm2 = sqrt((m11 - m22) * (m11 - m22) + 4.0 * m12 * m12); + float lambda1 = ((lambdaTerm1 + lambdaTerm2) / 2.0); + float lambda2 = ((lambdaTerm1 - lambdaTerm2) / 2.0); + r.a = 1.0 / sqrt(lambda1); + r.b = 1.0 / sqrt(lambda2); + r.valid = lambda1 > 0.0 && lambda2 > 0.0; + if (abs(m11 - m22) < 1e-6 && abs(m12) < 1e-6) { + r.u1 = vec2(1.0, 0.0); + } else if (m11 >= m22) { + r.u1 = normalize(vec2(lambda1 - m22, m12)); + } else { + r.u1 = normalize(vec2(m12, lambda1 - m11)); + } + r.u2 = vec2(-r.u1.y, r.u1.x); + return r; +} +`];function fL(i){const e=i.A,t=i.B/2,n=i.C,s=i.D,r=i.E,o=i.F,a=2*(t*t-e*n),l=(n*s-t*r)/a,c=(e*r-t*s)/a,d=1/(e*l*l+2*t*l*c+n*c*c-o),u=d*e,h=d*t,p=d*n,m=u+p,g=Math.sqrt((u-p)*(u-p)+4*h*h),v=(m+g)/2,y=(m-g)/2,S=1/Math.sqrt(v),w=1/Math.sqrt(y);let b;u>=p?b=C.Zc.fromValues(v-p,h):b=C.Zc.fromValues(h,v-u),C.Zc.normalize(b,b);const x=C.Zc.fromValues(-b[1],b[0]);return{k:C.Zc.fromValues(l,c),u1:b,u2:x,a:S,b:w,lambda1:v,lambda2:y,m11:u,m12:h,m22:p,valid:v>0&&y>0}}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function gL(i,e){const t=new Float32Array((i+1)*(e+1)*3);let n=0;for(let s=0;s<=i;++s){const r=s*Math.PI/i,o=Math.sin(r),a=Math.cos(r);for(let l=0;l<=e;++l){const c=l*2*Math.PI/e,d=Math.sin(c),u=Math.cos(c);t[n++]=u*o,t[n++]=a,t[n++]=d*o}}return t}function mL(i,e){const t=new Uint16Array(i*e*6);let n=0;for(let s=0;s{const r=s.vertexShaderInputBinders.CenterAndRadii;r.enable(1),this.gl.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER,t.buffer.buffer),r.bind(this.geometryDataStride,t.bufferOffset),n(s),r.disable()})}}class SL extends qv{constructor(){super(...arguments),this.sphereRenderHelper=this.registerDisposer(new vL(this.gl,10,10)),this.shaderGetter=this.getDependentShader("annotation/ellipsoid/projection",e=>{this.defineShader(e),this.sphereRenderHelper.defineShader(e),e.addUniform("highp vec4","uLightDirection"),e.addUniform("highp mat4","uNormalTransform"),e.addVarying("highp float","vClipCoefficient"),e.setVertexMain(` +SubspaceParams params = getSubspaceParams(); +if (params.cull) { + gl_Position = vec4(2.0, 0.0, 0.0, 1.0); + return; +} +vClipCoefficient = params.clipCoefficient; +${this.invokeUserMain} +emitSphere(uModelViewProjection, uNormalTransform, params.subspaceCenter, params.subspaceRadii, uLightDirection); +${this.setPartIndex(e)}; +`),e.setFragmentMain(` +emitAnnotation(vec4(vColor.rgb * vLightingFactor, vColor.a * vClipCoefficient)); +`)}),this.tempLightVec=new Float32Array(4)}draw(e){this.enable(this.shaderGetter,e,t=>{const{gl:n}=t,s=this.tempLightVec,{lightDirection:r,ambientLighting:o,directionalLighting:a}=e.renderContext;C.eR.scale(s,r,a),s[3]=o,n.uniform4fv(t.uniform("uLightDirection"),s),n.uniformMatrix4fv(t.uniform("uNormalTransform"),!1,C.pB.transpose(C.pB.create(),e.renderSubspaceInvModelMatrix)),this.sphereRenderHelper.draw(t,e.count)})}}class bL extends qv{constructor(){super(...arguments),this.shaderGetter=this.getDependentShader("annotation/ellipsoid/crossSection",e=>{xi(e),this.defineShader(e),e.addUniform("highp mat4","uViewportToObject"),e.addUniform("highp mat4","uObjectToViewport"),e.addUniform("highp mat4","uViewportToDevice"),e.addAttribute("highp vec2","aCornerOffset"),e.addVarying("highp vec2","vCircleCoord"),e.addVarying("highp float","vClipCoefficient"),e.addVertexCode(uL),e.addVertexCode(pL),e.addVertexCode(wc),e.setVertexMain(` +SubspaceParams params = getSubspaceParams(); +if (params.cull) { + gl_Position = vec4(2.0, 0.0, 0.0, 1.0); + return; +} +vClipCoefficient = params.clipCoefficient; +mat3 Aobject = mat3(0.0); +for (int i = 0; i < 3; ++i) { + float r = max(params.subspaceRadii[i], 1e-3); + Aobject[i][i] = 1.0 / (r * r); +} +mat3 RviewportToObject = mat3(uViewportToObject); +mat3 Aviewport = transpose(RviewportToObject) * Aobject * RviewportToObject; +vec3 cViewport = (uObjectToViewport * vec4(params.subspaceCenter, 1.0)).xyz; +EllipseQuadraticForm quadraticForm = computeCrossSectionEllipse(Aviewport, cViewport); +vec2 u1, u2; +float a, b; +CenterOrientEllipse centerOrient = computeCenterOrientEllipse(quadraticForm); +vec2 cornerOffset = getQuadVertexPosition(vec2(-1.0, -1.0), vec2(1.0, 1.0)); +vec2 viewportCorner = centerOrient.k + + centerOrient.u1 * cornerOffset.x * centerOrient.a + + centerOrient.u2 * cornerOffset.y * centerOrient.b; +if (centerOrient.valid) { + gl_Position = uViewportToDevice * vec4(viewportCorner, 0.0, 1.0); +} else { + gl_Position = vec4(2.0, 0.0, 0.0, 1.0); +} +vCircleCoord = cornerOffset; +${this.invokeUserMain} +${this.setPartIndex(e)}; +`),e.setFragmentMain(` +if (dot(vCircleCoord, vCircleCoord) > 1.0) { + discard; +} +emitAnnotation(vec4(vColor.rgb, vColor.a * vClipCoefficient)); +`)}),this.vertexIdHelper=this.registerDisposer(Qn.get(this.gl))}draw(e){this.enable(this.shaderGetter,e,t=>{const{gl:n}=t,s=e.renderContext.sliceView.projectionParameters.value,r=C.pB.multiply(Kv,e.renderSubspaceInvModelMatrix,s.invViewMatrix);n.uniformMatrix4fv(t.uniform("uViewportToObject"),!1,r),n.uniformMatrix4fv(t.uniform("uViewportToDevice"),!1,s.projectionMat);const o=Kv;C.pB.invert(o,r),n.uniformMatrix4fv(t.uniform("uObjectToViewport"),!1,o);const{vertexIdHelper:a}=this;if(a.enable(),Ao(n,1,e.count),a.disable(),yL){const l=C.eR.fromValues(3406.98779296875,3234.910400390625,4045),c=C.eR.fromValues(10,10,10),d=C.w0.create();d[0]=1/(c[0]*c[0]),d[4]=1/(c[1]*c[1]),d[8]=1/(c[2]*c[2]);const u=C.w0.fromMat4(C.w0.create(),r),h=C.w0.multiply(C.w0.create(),C.w0.transpose(C.w0.create(),u),d);C.w0.multiply(h,h,u);const p=C.eR.transformMat4(C.eR.create(),l,o);console.log("Aviewport",h),console.log("cViewport",p);const m=hL(h,p),g=fL(m);console.log(m),console.log(g)}})}}Xo(Re.ELLIPSOID,{sliceViewRenderHelper:bL,perspectiveViewRenderHelper:SL,defineShaderNoOpSetters(i){i.addVertexCode(` +void setEllipsoidFillColor(vec4 color) {} +`)},pickIdsPerInstance:1,snapPosition:()=>{},getRepresentativePoint(i,e){i.set(e.center)},updateViaRepresentativePoint(i,e){return{...i,center:new Float32Array(e)}}});/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Xv=C.pB.create(),Zv=C.eR.create();function ey(i){i.addUniform("highp vec3","uTranslation"),i.addUniform("highp mat4","uProjectionMatrix"),i.addUniform("highp vec3","uChunkDataSize"),i.addUniform("highp vec3","uLowerClipBound"),i.addUniform("highp vec3","uUpperClipBound"),i.setFragmentMain(` +emit(vec4(1.0, 1.0, 1.0, getLineAlpha()), 0u); +`)}const CL={defineShader(i){ey(i),In(i),i.addVertexCode(` +const vec3[24] boxCornerOffsets = vec3[]( + vec3(0, 0, 0), vec3(0, 0, 1), // e1 + vec3(1, 0, 0), vec3(1, 0, 1), // e2 + vec3(0, 1, 0), vec3(0, 1, 1), // e3 + vec3(1, 1, 0), vec3(1, 1, 1), // e4 + vec3(0, 0, 0), vec3(0, 1, 0), // e5 + vec3(0, 0, 1), vec3(0, 1, 1), // e6 + vec3(1, 0, 0), vec3(1, 1, 0), // e7 + vec3(1, 0, 1), vec3(1, 1, 1), // e8 + vec3(0, 0, 0), vec3(1, 0, 0), // e9 + vec3(0, 0, 1), vec3(1, 0, 1), // e10 + vec3(0, 1, 0), vec3(1, 1, 0), // e11 + vec3(0, 1, 1), vec3(1, 1, 1) // e12 +); +`),i.setVertexMain(` +int edgeIndex = gl_VertexID / ${Ut}; +vec3 cornerA = max(uLowerClipBound, min(uUpperClipBound, uTranslation)); +vec3 cornerB = max(uLowerClipBound, min(uUpperClipBound, uTranslation + uChunkDataSize)); +vec3 vertexPosition1 = mix(cornerA, cornerB, boxCornerOffsets[edgeIndex * 2]); +vec3 vertexPosition2 = mix(cornerA, cornerB, boxCornerOffsets[edgeIndex * 2 + 1]); +emitLine(uProjectionMatrix * vec4(vertexPosition1, 1.0), + uProjectionMatrix * vec4(vertexPosition2, 1.0), + 2.0); +`)},initialize(i,e){vn(i,e,1)},draw(i,e,t){const{gl:n}=i,s=Xv,{chunkLayout:r}=e;C.pB.multiply(s,t.viewProjectionMat,r.transform),n.uniformMatrix4fv(i.uniform("uProjectionMatrix"),!1,s),n.uniform3fv(i.uniform("uChunkDataSize"),r.size),n.uniform3fv(i.uniform("uLowerClipBound"),e.lowerClipDisplayBound),n.uniform3fv(i.uniform("uUpperClipBound"),e.upperClipDisplayBound);const o=r.size,{curPositionInChunks:a,chunkDisplayDimensionIndices:l}=e,c=Zv;for(let d=0;d<3;++d){const u=l[d];c[d]=(u===-1?0:a[u])*o[d]}n.uniform3fv(i.uniform("uTranslation"),c),mn(n,Hd,1)}},wL={defineShader(i){Va(i),ey(i),In(i),i.setVertexMain(` +int vertexIndex1 = gl_VertexID / ${Ut}; +int vertexIndex2 = vertexIndex1 == 5 ? 0 : vertexIndex1 + 1; +vec3 vertexPosition1 = getBoundingBoxPlaneIntersectionVertexPosition(uChunkDataSize, uTranslation, uLowerClipBound, uUpperClipBound, vertexIndex1); +vec3 vertexPosition2 = getBoundingBoxPlaneIntersectionVertexPosition(uChunkDataSize, uTranslation, uLowerClipBound, uUpperClipBound, vertexIndex2); +emitLine(uProjectionMatrix * vec4(vertexPosition1, 1.0), + uProjectionMatrix * vec4(vertexPosition2, 1.0), + 2.0); +`)},initialize(i,e){vn(i,e,1)},draw(i,e,t){const{gl:n}=i,s=Xv,{chunkLayout:r}=e;C.pB.multiply(s,t.viewProjectionMat,r.transform),n.uniformMatrix4fv(i.uniform("uProjectionMatrix"),!1,s),n.uniform3fv(i.uniform("uChunkDataSize"),r.size),n.uniform3fv(i.uniform("uLowerClipBound"),e.lowerClipDisplayBound),n.uniform3fv(i.uniform("uUpperClipBound"),e.upperClipDisplayBound);const o=r.size,{curPositionInChunks:a,chunkDisplayDimensionIndices:l}=e,c=Zv;for(let d=0;d<3;++d){const u=l[d];c[d]=(u===-1?0:a[u])*o[d]}n.uniform3fv(i.uniform("uTranslation"),c),zd(i,t.viewportNormalInGlobalCoordinates,t.centerDataPosition,r.transform,r.invTransform),mn(n,6,1)}};var xL=Object.defineProperty,EL=Object.getOwnPropertyDescriptor,TL=(i,e,t,n)=>{for(var s=n>1?void 0:n?EL(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&xL(e,t,s),s};/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const DL=C.pB.create();function IL(i){if(i!==void 0)return e=>{const{relatedSegments:t}=e;if(t===void 0)return!1;for(let n=0,s=t.length;n{const r={id:this.rpcId,segmentationStates:this.serializeDisplayState()};this.rpc.invoke(qE,r)};this.registerDisposer(t.changed.add(s))}serializeDisplayState(){const{value:i}=this.segmentationStates;if(i!==void 0)return i.map(e=>e==null?e:jm(e.segmentationGroupState.value))}};Qd=TL([Zt(KE)],Qd);class RL extends T.O8{constructor(e,t){super(),this.chunkManager=e,this.state=t,this.layerChunkProgressInfo=new fo,this.numPickIds=0,this.generation=-1,this.redrawNeeded=new j.IY,this.serializedAnnotations=void 0,this.handleChangeAffectingBuffer=()=>{this.generation=-1,this.redrawNeeded.dispatch()},this.segmentationStates=this.registerDisposer((0,_.Uq)((s,r)=>{const{displayState:o,source:a}=this.state,{relationshipStates:l}=o;return o.displayUnfiltered.value?void 0:a.relationships.map(c=>{const d=l.get(c);return d.showMatches.value?d.segmentationState.value:void 0})},[this.state.displayState.relationshipStates,this.state.displayState.ignoreNullSegmentFilter],(s,r)=>s===void 0||r===void 0?s===r:(0,F.r1)(s,r))),this.registerDisposer(t),this.registerDisposer(this.source.changed.add(this.handleChangeAffectingBuffer)),this.registerDisposer((0,_.no)((s,r)=>{if(this.handleChangeAffectingBuffer(),r!==void 0)for(const o of r)o!=null&&s.registerDisposer((0,_.aM)((a,l)=>{a.registerDisposer(l.visibleSegments.changed.add(()=>this.handleChangeAffectingBuffer())),a.registerDisposer(l.segmentEquivalences.changed.add(()=>this.handleChangeAffectingBuffer()))},o.segmentationGroupState))},this.segmentationStates)),this.source instanceof hs||(this.sharedObject=this.registerDisposer(new Qd(e,this.source,this.segmentationStates,this.layerChunkProgressInfo)));const{displayState:n}=this.state;this.registerDisposer(n.color.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(n.shader.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(n.shaderControls.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(this.hoverState.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(this.transform.changed.add(this.redrawNeeded.dispatch))}get source(){return this.state.source}get transform(){return this.state.transform}get hoverState(){return this.state.displayState.hoverState}get visibility(){const{sharedObject:e}=this;if(e!==void 0)return e.visibility}get gl(){return this.chunkManager.gl}updateBuffer(){const{source:e}=this;if(e instanceof hs){const t=e.changed.count;if(this.generation!==t){let{buffer:n}=this;n===void 0&&(n=this.buffer=this.registerDisposer(new At(this.chunkManager.gl))),this.generation=t;const s=this.serializedAnnotations=LL(e,IL(this.segmentationStates.value));n.setData(this.serializedAnnotations.data),this.numPickIds=hg(s)}}}}function ty(i){const{chunkTransform:e}=i,{unpaddedRank:t}=e.modelTransform,n=new Float32Array(t*2),s=new Float32Array(t*3);s.fill(0),n.fill(1,t);const{numChunkDisplayDims:r,chunkDisplayDimensionIndices:o}=i;for(let a=0;a{t.addMessage({severity:Tn.error,message:l})};if(i.error!==void 0)return n(i.error);const s=Zh(i.modelTransform,e.displayDimensionIndices);let r;try{r=ep(i,s)}catch(l){return n(l.message)}const{modelClipBounds:o,renderSubspaceTransform:a}=ty(r);return{chunkTransform:i,chunkDisplayTransform:r,modelClipBounds:o,renderSubspaceTransform:a}}function Kd(i,e){class t extends i{constructor(s,r){super(),this.base=s,this.renderScaleHistogram=r,this.curRank=-1,this.renderHelpers=[],this.isAnnotation=!0;const o=s.visibility;o!==void 0&&this.registerDisposer(o.add(this.visibility)),this.registerDisposer(this.renderScaleHistogram.visibility.add(this.visibility)),this.registerDisposer(()=>{for(const a of this.renderHelpers)a.dispose()}),this.role=s.state.role,this.registerDisposer(s.redrawNeeded.add(this.redrawNeeded.dispatch)),this.registerDisposer(s.source.properties.changed.add(()=>{this.handleRankChanged(!0)})),this.handleRankChanged(),this.registerDisposer(this.base.state.displayState.shaderControls.histogramSpecifications.producerVisibility.add(this.visibility))}handleRankChanged(s=!1){const{rank:r}=this.base.source;if(!s&&r===this.curRank)return;this.curRank=r,this.tempChunkPosition=new Float32Array(r);const{renderHelpers:o,gl:a}=this;for(const d of o)d.dispose();const{properties:{value:l}}=this.base.source,{displayState:c}=this.base.state;for(const d of Xt){const u=Tr(d),h=u[e],p=o[d]=new h(a,d,r,l,c.shaderControls,c.fallbackShaderControls,c.shaderError);p.pickIdsPerInstance=u.pickIdsPerInstance,p.targetIsSliceView=e==="sliceViewRenderHelper"}}attach(s){super.attach(s),this.handleRankChanged();const{chunkTransform:r}=this,o=s.view.displayDimensionRenderInfo.value;s.state={chunkTransform:r,displayDimensionRenderInfo:o,chunkRenderParameters:ny(r,o,s.messages)}}updateAttachmentState(s){const r=s.state;this.handleRankChanged();const{chunkTransform:o}=this,a=s.view.displayDimensionRenderInfo.value;return r!==void 0&&r.chunkTransform===o&&r.displayDimensionRenderInfo===a?r.chunkRenderParameters:(r.chunkTransform=o,r.displayDimensionRenderInfo=a,r.chunkRenderParameters=ny(o,a,s.messages))}get chunkTransform(){return this.base.state.chunkTransform.value}updateModelClipBounds(s,r){const{modelClipBounds:o}=r,a=this.curRank,{chunkTransform:l}=r;gs(o.subarray(0,a),s.projectionParameters.globalPosition,this.base.state.localPosition.value,l.layerRank,l.combinedGlobalLocalToChunkTransform)}get gl(){return this.base.chunkManager.gl}drawGeometryChunkData(s,r,o,a=1){if(!s.bufferValid){let{buffer:l}=s;l===void 0&&(l=s.buffer=new At(this.gl));const{serializedAnnotations:c}=s;l.setData(c.data),s.numPickIds=hg(c),s.bufferValid=!0}this.drawGeometry(s,r,o,a)}drawGeometry(s,r,o,a=1){const{base:l}=this,{chunkDisplayTransform:c}=o,{serializedAnnotations:d}=s,{typeToIdMaps:u,typeToOffset:h}=d;let p=0;r.emitPickID&&(p=r.pickIDs.register(this,s.numPickIds,0,0,s));const m=l.hoverState.value,g=C.pB.multiply(DL,r.projectionParameters.viewProjectionMat,c.displaySubspaceModelMatrix),v={annotationLayer:l,renderContext:r,selectedIndex:0,basePickId:p,buffer:s.buffer,bufferOffset:0,count:0,modelViewProjectionMatrix:g,modelClipBounds:o.modelClipBounds,subspaceMatrix:o.renderSubspaceTransform,renderSubspaceModelMatrix:c.displaySubspaceModelMatrix,renderSubspaceInvModelMatrix:c.displaySubspaceInvModelMatrix,chunkDisplayTransform:c},y=this.base.state.displayState.shaderControls.histogramSpecifications.visibleHistograms>0;for(const S of Xt){const w=u[S];let b=w.size;if(b>0){const x=Tr(S);let E=4294967295;if(m!==void 0){const I=w.get(m.id);I!==void 0&&(E=I*x.pickIdsPerInstance)}b=Math.round(b*a),v.count=b,v.bufferOffset=h[S],v.selectedIndex=E;const D=this.renderHelpers[S];D.draw(v),y&&(D.computeHistograms(v,r.frameNumber),r.bindFramebuffer()),v.basePickId+=b*x.pickIdsPerInstance}}}updateMouseState(s,r,o,a){const l=a,{serializedAnnotations:c}=l,{typeToIds:d,typeToOffset:u}=c,h=this.curRank,p=this.chunkTransform;if(p.error===void 0)for(const m of Xt){const g=d[m],v=Tr(m),{pickIdsPerInstance:y}=v;if(oclass extends i{constructor(){super(...arguments),this.layerChunkProgressInfo=this.base.layerChunkProgressInfo}draw(t,n){const s=this.updateAttachmentState(n);if(this.curRank===0||s===void 0)return;this.updateModelClipBounds(t,s);const{source:r}=this.base;if(r instanceof hs){const{base:o}=this;o.updateBuffer(),this.drawGeometry(o,t,s)}else{const{renderScaleHistogram:o}=this;o.begin(this.base.chunkManager.chunkQueueManager.frameNumberCounter.frameNumber),this.drawGeometryChunkData(r.temporary.data,t,s);const{value:a}=this.base.segmentationStates;let l=0,c=0;if(a!==void 0)for(let d=0,u=a.length;d{const g=Sn(m),v=p.get(g);if(v!==void 0&&v.state===Ue.GPU_MEMORY){const{data:y}=v;if(y===void 0)return;this.drawGeometryChunkData(y,t,s),++l}else++c})}o.add(Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY,l,c)}}isReady(){const{base:t}=this,{source:n}=t;if(!(n instanceof Rr))return!0;const{value:s}=this.base.segmentationStates;if(s===void 0)return!0;for(let r=0,o=s.length;r{const u=Sn(d);l.has(u)||(c=!0)}),c)return!1}return!0}},sy=Kd(Gi,"perspectiveViewRenderHelper");class kL extends iy(sy){}const ry=i=>{class e extends i{constructor(n){super(n.annotationLayer,n.renderScaleHistogram),this.wireFrameRenderHelper=this instanceof Fi?wL:CL,this.wireFrameShaderGetter=Ai(this,this.gl,{memoizeKey:`annotation/wireFrameShader:${this instanceof Fi}`,parameters:(0,_.XZ)(void 0),defineShader:o=>{this.wireFrameRenderHelper.defineShader(o)}}),this.renderScaleTarget=n.renderScaleTarget,this.registerDisposer(this.renderScaleTarget.changed.add(this.redrawNeeded.dispatch));const s=this.registerDisposer(new Dr(this.layerChunkProgressInfo)),r=this.base.chunkManager.rpc;s.RPC_TYPE_ID=YE,s.initializeCounterpart(r,{chunkManager:this.base.chunkManager.rpcId,localPosition:this.registerDisposer(ft.makeFromExisting(r,this.base.state.localPosition)).rpcId,renderScaleTarget:this.registerDisposer(ft.makeFromExisting(r,this.renderScaleTarget)).rpcId}),this.backend=s}attach(n){super.attach(n),n.state.sources=n.registerDisposer((0,_.no)((s,r,o)=>{const a=sa(o,r,l=>this.base.state.source.getSources(l),n.messages,this);for(const l of a)for(const c of l)s.registerDisposer(c.source),Object.assign(c,ty(c.chunkDisplayTransform));return n.view.flushBackendProjectionParameters(),this.backend.rpc.invoke(QE,{layer:this.backend.rpcId,view:n.view.rpcId,displayDimensionRenderInfo:o,sources:ta(a)}),this.redrawNeeded.dispatch(),a},this.base.state.transform,n.view.displayDimensionRenderInfo))}draw(n,s){const r=this.updateAttachmentState(s);if(this.curRank===0||r===void 0)return;const o=s.state.sources.value;if(o.length===0)return;this.updateModelClipBounds(n,r);const{renderScaleHistogram:a}=this;a.begin(this.base.chunkManager.chunkQueueManager.frameNumberCounter.frameNumber);const{projectionParameters:l}=n;let c;if(n.wireFrame){const{shader:d}=this.wireFrameShaderGetter(n.emitter);if(d===null)return;d.bind(),this.wireFrameRenderHelper.initialize(d,l),c=d}ng(l,this.base.state.localPosition.value,this.renderScaleTarget.value,o[0],()=>{},(d,u,h,p,m)=>{const g=d.source.chunks.get(d.curPositionInChunks.join());let v;if(g===void 0||g.state!==Ue.GPU_MEMORY)v=0;else{const{data:y}=g;if(y===void 0)return;c!==void 0?this.wireFrameRenderHelper.draw(c,d,l):this.drawGeometryChunkData(y,n,r,h),v=1}a.add(p,m,v,1-v)})}isReady(n,s){const r=this.updateAttachmentState(s);if(this.curRank===0||r===void 0)return;const o=s.state.sources.value;if(o.length===0)return;this.updateModelClipBounds(n,r);const{projectionParameters:a}=n;let l=!0;return ng(a,this.base.state.localPosition.value,this.renderScaleTarget.value,o[0],()=>{},(c,d,u,h,p)=>{const m=c.source.chunks.get(c.curPositionInChunks.join());if(m===void 0||m.state!==Ue.GPU_MEMORY){l=!1;return}}),l}}return e},PL=ry(sy),AL=ry(Kd(Fi,"sliceViewRenderHelper")),ML=iy(Kd(Fi,"sliceViewRenderHelper"));var Fa=G(4499);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function qd(i={}){return Ne({svg:Fa,...i})}var NL=G(1252);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Mn(i={}){const e=Ne({svg:NL,...i}),t=e.firstElementChild;return t.style.fill="white",e}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const oy=10,Ua=.5;class OL{constructor(){this.anchorIndex=0,this.anchorClientOffset=0}splice(e){let{anchorIndex:t}=this,n=0;for(const s of e){if(n+=s.retainCount,te;--t)n-=this.getEstimatedSize(t-1);return n}getRangeSize(e,t){let n=0;const{itemSize:s,averageSize:r}=this;for(let o=e;on+s,0),this.numItemsInTotalKnownSize=t.reduce(n=>n+1,0)}}function VL(i,e,t,n,s,r){const{anchorIndex:o,anchorClientOffset:a}=r,l=s.getEstimatedOffset(o);let c,d,u,h,p;if(n===0||s.totalKnownSize===0)c=Math.max(0,o-oy/2),d=Math.min(t,c+oy),p=o,u=0,h=a;else{const m=s.getEstimatedTotalSize(),g=Math.max(0,m-n);h=l-a,h=Math.max(0,Math.min(g,h));const v=h-2*Ua*n,y=h-Ua*n,S=h+n+Ua*n,w=l-a+n+2*Ua*n;c=Math.min(t,e.startIndex);let b=s.getEstimatedOffset(c,o,l);if(b=y)break;b+=E}if(b>=y)for(;b>v&&c>0;--c){const E=s.getEstimatedSize(c-1);b-=E}d=Math.min(t,e.endIndex);let x=s.getEstimatedOffset(d,o,l);if(x=w)for(;d>c;--d){const E=s.getEstimatedSize(d-1);if(x-Ed;--p){const E=s.getEstimatedSize(p-1);u-=E}}i.startIndex=c,i.endIndex=d,i.anchorIndex=p,i.anchorOffset=u,i.scrollOffset=h}function BL(i,e){const t=e.getEstimatedOffset(i.anchorIndex),n=i.anchorOffset;i.anchorOffset=t,i.scrollOffset+=t-n}function FL(i,e){return i.startIndexe.endIndex||i.viewportWidth!==0&&e.viewportWidth===0}class Wr extends T.O8{constructor(e){super(),this.element=document.createElement("div"),this.scrollContent=document.createElement("div"),this.header=document.createElement("div"),this.body=document.createElement("div"),this.topItems=document.createElement("div"),this.bottomItems=document.createElement("div"),this.renderedItems=[],this.renderGeneration=-1,this.listGeneration=-1,this.newRenderedItems=[],this.state=new OL,this.renderParams=new ay,this.newRenderParams=new ay,this.sizes=new _L,this.debouncedUpdateView=this.registerCancellable((0,Qe.t)(()=>this.updateView())),this.resizeObserver=new ResizeObserver(()=>this.updateView());const{selectedIndex:t}=e;t!==void 0&&(this.state.anchorIndex=t,this.state.anchorClientOffset=0);const n=this.source=e.source;this.sizes.itemSize.length=n.length;const{element:s,header:r,body:o,scrollContent:a,topItems:l,bottomItems:c}=this;this.resizeObserver.observe(s),this.registerDisposer(()=>this.resizeObserver.disconnect()),s.appendChild(a),s.style.overflowAnchor="none",a.appendChild(r),a.appendChild(o),r.style.position="sticky",r.style.zIndex="1",r.style.top="0",e.horizontalScroll?(a.style.width="min-content",a.style.minWidth="100%",r.style.width="min-content",r.style.minWidth="100%",c.style.width="min-content",c.style.minWidth="100%"):(a.style.width="100%",r.style.width="100%",c.style.width="100%"),o.appendChild(l),o.appendChild(c),l.style.width="min-content",l.style.position="relative",l.style.height="0",l.style.minWidth="100%",c.style.height="0",c.style.position="relative",s.addEventListener("scroll",()=>{const d=s.scrollTop;this.state.anchorClientOffset=this.renderParams.anchorOffset-d,this.renderParams.scrollOffset=d,this.debouncedUpdateView()}),n.changed!==void 0&&this.registerDisposer(n.changed.add(d=>{this.sizes.splice(d),this.state.splice(d),this.renderedItems.length=0,this.debouncedUpdateView()})),n.renderChanged!==void 0&&this.registerDisposer(n.renderChanged.add(this.debouncedUpdateView))}updateView(){const{element:e}=this,t=e.clientHeight-this.header.offsetHeight,n=e.clientWidth,{source:s,state:r,sizes:o}=this,a=s.length,{body:l,topItems:c,bottomItems:d}=this,{changed:u,renderChanged:h}=s;let p;for(;;){p=this.newRenderParams;const v=this.renderParams;VL(p,v,a,t,o,r),p.viewportWidth=n;let y;if(h!==void 0&&h.count!==this.renderGeneration||u!==void 0&&u.count!==this.listGeneration?(this.renderGeneration=h===void 0?-1:h.count,this.listGeneration=u===void 0?-1:u.count,y=!0,this.renderedItems.length=0):y=!1,!y&&!FL(p,v)){v.scrollOffset=p.scrollOffset,p=v;break}this.renderParams=p,this.newRenderParams=v;const S=this.renderedItems,w=this.newRenderedItems;w.length=0,this.renderedItems=w,this.newRenderedItems=S;const{source:b}=this,{render:x}=b,{startIndex:E,endIndex:D,anchorIndex:I}=p;function*L(N,k){for(let O=N;Os&&n>s+this.element.offsetHeight)this.state.anchorIndex=e+1,this.state.anchorClientOffset=this.element.offsetHeight;else return;this.debouncedUpdateView()}disposed(){at(this.element)}}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class ly extends T.O8{constructor(){super(...arguments),this.changed=new j.IY,this.isLoadingChanged=new j.IY,this.states=[],this.relationships=[],this.loadingCount=0}get value(){return this.states}get isLoading(){return this.loadingCount!==0}markLoading(){return this.loadingCount++,()=>{--this.loadingCount===0&&this.isLoadingChanged.dispatch()}}sort(){this.states.sort((e,t)=>{const n=e.sourceIndex-t.sourceIndex;return n!==0?n:e.subsourceIndex-t.subsourceIndex})}updateRelationships(){const e=new Set;for(const t of this.states)for(const n of t.source.relationships)e.add(n);this.relationships=Array.from(e)}add(e){return this.states.push(e),this.sort(),this.updateRelationships(),this.changed.dispatch(),()=>{const t=this.states.indexOf(e);this.states.splice(t,1),this.updateRelationships(),this.changed.dispatch()}}}function UL(i,e){switch(e.type){case Re.AXIS_ALIGNED_BOUNDING_BOX:case Re.LINE:i.set(e.pointA);break;case Re.POINT:i.set(e.point);break;case Re.ELLIPSOID:i.set(e.center);break}}function $L(i,e){switch(e.type){case Re.AXIS_ALIGNED_BOUNDING_BOX:case Re.LINE:Ah(i,e.pointA,e.pointB),dC(i,i,.5);break;case Re.POINT:i.set(e.point);break;case Re.ELLIPSOID:i.set(e.center);break}}function cy(i,e,t){e.error===void 0&&i.setLayerPosition(e.modelTransform,t)}function dy(i,e,t){const{layerRank:n}=e,s=new Float32Array(n);Ft[i.type].visitGeometry(i,(r,o)=>{s.set(r);const a=new Float32Array(n);(o?De._U:De.vo)(a,e.chunkToLayerTransform,n+1,s,n),t(a,o)})}const uy=(i,e,t)=>{const n=t.chunkTransform.value,{layerRank:s}=n,r=new Float32Array(s),o=new Float32Array(s);UL(r,e),De.vo(o,n.chunkToLayerTransform,s+1,r,s),cy(i,n,o),t.displayState.swapVisibleSegmentsOnMove.value&&GL(e,t,!0)},GL=(i,e,t=!1)=>{const{relatedSegments:n}=i;if(n){const{source:s,displayState:r}=e,{relationships:o}=s,{relationshipStates:a}=r;for(let l=0,c=o.length;lthis.render(h),changed:new j.HN},this.virtualList=new Wr({source:this.virtualListSource}),this.listElements=[],this.updated=!1,this.mutableControls=document.createElement("div"),this.headerRow=document.createElement("div"),this.attachedAnnotationStates=new Map,this.forceUpdateView=()=>{this.updated=!1,this.updateView()},this.globalDimensionIndices=[],this.localDimensionIndices=[],this.curCoordinateSpaceGeneration=-1,this.prevCoordinateSpaceGeneration=-1,this.columnWidths=[],this.gridTemplate="",this.selectedAnnotationState=(0,_.ol)((h,p)=>{if(h===void 0)return;const{layer:m}=this,g=h.layers.find(S=>S.layer===m)?.state;if(g===void 0)return;const{annotationId:v}=g;if(v===void 0)return;const y=this.annotationStates.states.find(S=>S.sourceIndex===g.annotationSourceIndex&&(g.annotationSubsource===void 0||S.subsourceId===g.annotationSubsource));if(y!==void 0)return{annotationId:v,annotationLayerState:y,pin:p}},this.layer.manager.root.selectionState,this.layer.manager.root.selectionState.pin),this.element.classList.add("neuroglancer-annotation-layer-view"),this.registerDisposer(this.visibility.changed.add(()=>this.updateView())),this.registerDisposer(this.annotationStates.changed.add(()=>this.updateAttachedAnnotationLayerStates())),this.headerRow.classList.add("neuroglancer-annotation-list-header");const n=document.createElement("div");n.className="neuroglancer-annotation-toolbox",e.initializeAnnotationLayerViewTab(this);const s=this.registerDisposer(new hi(this.displayState.color));s.element.title="Change annotation display color",this.registerDisposer(new en((0,_.ol)(h=>h.match(/\bdefaultColor\b/)!==null,t.shaderControls.processedFragmentMain),s.element)),n.appendChild(s.element);const{mutableControls:r}=this,o=Ne({text:Ft[Re.POINT].icon,title:"Annotate point",onClick:()=>{this.layer.tool.value=new yy(this.layer,{})}});r.appendChild(o);const a=Ne({text:Ft[Re.AXIS_ALIGNED_BOUNDING_BOX].icon,title:"Annotate bounding box",onClick:()=>{this.layer.tool.value=new Xd(this.layer,{})}});r.appendChild(a);const l=Ne({text:Ft[Re.LINE].icon,title:"Annotate line",onClick:()=>{this.layer.tool.value=new Ga(this.layer,{})}});r.appendChild(l);const c=Ne({text:Ft[Re.ELLIPSOID].icon,title:"Annotate ellipsoid",onClick:()=>{this.layer.tool.value=new Cy(this.layer,{})}});r.appendChild(c),n.appendChild(r),this.element.appendChild(n),this.element.appendChild(this.headerRow);const{virtualList:d}=this;d.element.classList.add("neuroglancer-annotation-list"),this.element.appendChild(d.element),this.virtualList.element.addEventListener("mouseleave",()=>{this.displayState.hoverState.value=void 0});const u=Im();this.registerDisposer(new tn(this.virtualList.element,u)),this.virtualList.element.title=u.describe(),this.registerDisposer(this.displayState.hoverState.changed.add(()=>this.updateHoverView())),this.registerDisposer(this.selectedAnnotationState.changed.add(()=>this.updateSelectionView())),this.registerDisposer(this.layer.localCoordinateSpace.changed.add(()=>{this.updateCoordinateSpace(),this.updateView()})),this.registerDisposer(this.layer.manager.root.coordinateSpace.changed.add(()=>{this.updateCoordinateSpace(),this.updateView()})),this.updateCoordinateSpace(),this.updateAttachedAnnotationLayerStates(),this.updateSelectionView()}get annotationStates(){return this.layer.annotationStates}updateAttachedAnnotationLayerStates(){const e=this.annotationStates.states,{attachedAnnotationStates:t}=this,n=new Map;for(const[s,r]of t)e.includes(s)||(t.delete(s),r.refCounted.dispose());for(const s of e){const r=t.get(s);if(r!==void 0){n.set(s,r);continue}const o=s.source,a=new T.O8;o instanceof hs&&(a.registerDisposer(o.childAdded.add(l=>this.addAnnotationElement(l,s))),a.registerDisposer(o.childUpdated.add(l=>this.updateAnnotationElement(l,s))),a.registerDisposer(o.childDeleted.add(l=>this.deleteAnnotationElement(l,s)))),a.registerDisposer(s.transform.changed.add(this.forceUpdateView)),n.set(s,{refCounted:a,annotations:[],idToIndex:new Map,listOffset:0})}this.attachedAnnotationStates=n,t.clear(),this.updateCoordinateSpace(),this.forceUpdateView()}updateCoordinateSpace(){const e=this.layer.localCoordinateSpace.value,t=this.layer.manager.root.coordinateSpace.value,n=[],s=[];for(let r=0,o=t.rank;r{const l=a.transform.value;return l.error!==void 0?!1:l.globalToRenderLayerDimensions[r]!==-1})&&n.push(r);for(let r=0,o=e.rank;r{const l=a.transform.value;return l.error!==void 0?!1:l.localToRenderLayerDimensions[r]!==-1})&&s.push(r);(!(0,F.r1)(n,this.globalDimensionIndices)||!(0,F.r1)(s,this.localDimensionIndices))&&(this.localDimensionIndices=s,this.globalDimensionIndices=n,++this.curCoordinateSpaceGeneration)}getRenderedAnnotationListElement(e,t,n=!1){const s=this.attachedAnnotationStates.get(e);if(s===void 0)return;const r=s.idToIndex.get(t);if(r===void 0)return;const o=s.listOffset+r;return n&&this.virtualList.scrollItemIntoView(r),this.virtualList.getItemElement(o)}clearSelectionClass(){const{previousSelectedState:e}=this;if(e===void 0)return;this.previousSelectedState=void 0;const t=this.getRenderedAnnotationListElement(e.annotationLayerState,e.annotationId);t!==void 0&&t.classList.remove("neuroglancer-annotation-selected")}clearHoverClass(){const{previousHoverId:e,previousHoverAnnotationLayerState:t}=this;if(t!==void 0){this.previousHoverAnnotationLayerState=void 0,this.previousHoverId=void 0;const n=this.getRenderedAnnotationListElement(t,e);n!==void 0&&n.classList.remove("neuroglancer-annotation-hover")}}updateSelectionView(){const e=this.selectedAnnotationState.value,{previousSelectedState:t}=this;if(t===e||t!==void 0&&e!==void 0&&t.annotationId===e.annotationId&&t.annotationLayerState===e.annotationLayerState&&t.pin===e.pin||(this.clearSelectionClass(),this.previousSelectedState=e,e===void 0))return;const n=this.getRenderedAnnotationListElement(e.annotationLayerState,e.annotationId,e.pin);n!==void 0&&n.classList.add("neuroglancer-annotation-selected")}updateHoverView(){const e=this.displayState.hoverState.value;let t,n;e!==void 0&&(t=e.id,n=e.annotationLayerState);const{previousHoverId:s,previousHoverAnnotationLayerState:r}=this;if(t===s&&n===r||(this.clearHoverClass(),this.previousHoverId=t,this.previousHoverAnnotationLayerState=n,t===void 0))return;const o=this.getRenderedAnnotationListElement(n,t);o!==void 0&&o.classList.add("neuroglancer-annotation-hover")}render(e){const{annotation:t,state:n}=this.listElements[e],{layer:s,gridTemplate:r,globalDimensionIndices:o,localDimensionIndices:a}=this,[l,c]=xy(s,t,n,r,o,a);for(const[u,h]of c.entries())this.setColumnWidth(u,h);l.addEventListener("mouseenter",()=>{this.displayState.hoverState.value={id:t.id,partIndex:0,annotationLayerState:n}});const d=this.selectedAnnotationState.value;return d!==void 0&&d.annotationLayerState===n&&d.annotationId===t.id&&l.classList.add("neuroglancer-annotation-selected"),l}setColumnWidth(e,t){t+=2;const{columnWidths:n}=this;n[e]>t||(n[e]=t,this.element.style.setProperty(`--neuroglancer-column-${e}-width`,`${t}ch`))}updateView(){if(!this.visible)return;if(this.curCoordinateSpaceGeneration!==this.prevCoordinateSpaceGeneration){this.updated=!1;const{columnWidths:s}=this;s.length=0;const{headerRow:r}=this,o=document.createElement("div");o.style.gridColumn="symbol";const a=document.createElement("div");a.style.gridColumn="delete",Me(r),r.appendChild(o);let l=0,c="[symbol] 2ch";const d=(p,m)=>{const g=document.createElement("div");g.classList.add("neuroglancer-annotations-view-dimension");const v=document.createElement("span");v.classList.add("neuroglancer-annotations-view-dimension-name"),v.textContent=p.names[m];const y=document.createElement("scale");y.classList.add("neuroglancer-annotations-view-dimension-scale"),y.textContent=Ri(p.scales[m],p.units[m],{precision:2}),g.appendChild(v),g.appendChild(y),g.style.gridColumn=`dim ${l+1}`,this.setColumnWidth(l,y.textContent.length+v.textContent.length+3),c+=` [dim] var(--neuroglancer-column-${l}-width)`,++l,r.appendChild(g)},u=this.layer.manager.root.coordinateSpace.value;for(const p of this.globalDimensionIndices)d(u,p);const h=this.layer.localCoordinateSpace.value;for(const p of this.localDimensionIndices)d(h,p);r.appendChild(a),c+=" [delete] 2ch",this.gridTemplate=c,r.style.gridTemplateColumns=c,this.prevCoordinateSpaceGeneration=this.curCoordinateSpaceGeneration}if(this.updated)return;let e=!1;const{listElements:t}=this;t.length=0;for(const[s,r]of this.attachedAnnotationStates){if(s.source.readonly||(e=!0),s.chunkTransform.value.error!==void 0)continue;const{source:o}=s,a=Array.from(o);r.annotations=a;const{idToIndex:l}=r;l.clear();for(let c=0,d=a.length;co.default)},r=t.source.add(s,!0);this.layer.selectAnnotation(t,r.id,!0),r.dispose()}}get description(){return"annotate point"}toJSON(){return fy}}function Hr(i,e){const t=e.chunkTransform.value;if(t.error!==void 0)return;const n=new Float32Array(t.modelTransform.unpaddedRank);if(gs(n,i.unsnappedPosition,e.localPosition.value,t.layerRank,t.combinedGlobalLocalToChunkTransform))return n}class Sy extends py{constructor(){super(...arguments),this.inProgressAnnotation=new _.B0(void 0)}trigger(e){const{annotationLayer:t,inProgressAnnotation:n}=this;if(t!==void 0&&e.updateUnconditionally()){const s=()=>{const r=n.value,o=r.reference,a=this.getUpdatedAnnotation(o.value,e,t);JSON.stringify(_l(a,t.source))!==JSON.stringify(_l(o.value,t.source))&&(r.annotationLayer.source.update(o,a),this.layer.selectAnnotation(t,o.id,!0))};if(n.value===void 0){const r=t.source.add(this.getInitialAnnotation(e,t),!1);this.layer.selectAnnotation(t,r.id,!0);const o=e.changed.add(s),a=()=>{o(),r.dispose()};n.value={annotationLayer:t,reference:r,disposer:a}}else{s();const r=n.value;r.annotationLayer.source.commit(r.reference),r.disposer(),n.value=void 0}}}disposed(){this.deactivate(),super.disposed()}deactivate(){const e=this.inProgressAnnotation.value;e!==void 0&&(e.annotationLayer.source.delete(e.reference),e.disposer(),this.inProgressAnnotation.value=void 0)}}class by extends Sy{getInitialAnnotation(e,t){const n=Hr(e,t);return{id:"",type:this.annotationType,description:"",pointA:n,pointB:n,properties:t.source.properties.value.map(s=>s.default)}}getUpdatedAnnotation(e,t,n){const s=Hr(t,n);return s===void 0?e:{...e,pointB:s}}}class Xd extends by{get description(){return"annotate bounding box"}getUpdatedAnnotation(e,t,n){const s=super.getUpdatedAnnotation(e,t,n),{pointA:r,pointB:o}=s,a=r.length;for(let l=0;l{const c=r[l];return a=a.filter(d=>c.findIndex(u=>P.R.equal(d,u))===-1),[...c,...a]}),s}toJSON(){return gy}}Ga.prototype.annotationType=Re.LINE;class Cy extends Sy{getInitialAnnotation(e,t){const n=Hr(e,t);return{type:Re.ELLIPSOID,id:"",description:"",segments:$a(t),center:n,radii:C.eR.fromValues(0,0,0),properties:t.source.properties.value.map(s=>s.default)}}getUpdatedAnnotation(e,t,n){const s=Hr(t,n);if(s===void 0)return e;const r=e.center,o=r.length;for(let a=0;anew yy(i,e)),Cr(my,(i,e)=>new Xd(i,e)),Cr(gy,(i,e)=>new Ga(i,e)),Cr(vy,(i,e)=>new Cy(i,e));const WL=Ae.fromObject({enter:{action:"commit"},escape:{action:"cancel"}});function HL(i,e,t,n){return new Wt(t,(s,r,o)=>{const a=document.createElement("div");a.classList.add("neuroglancer-related-segment-list"),s!=null&&o.registerDisposer($r(s,a));const l=document.createElement("div");l.classList.add("neuroglancer-related-segment-list-header");const c=Hn({title:"Copy segment IDs",onClick:()=>{mi(e.map(m=>m.toString()).join(", "))}});l.appendChild(c);let d;if(s!=null&&(d=document.createElement("input"),d.type="checkbox",d.addEventListener("change",()=>{const{visibleSegments:m}=s.segmentationGroupState.value,g=e.some(v=>!m.has(v));for(const v of e)m.set(v,g)}),l.appendChild(d)),n!==void 0){const m=Mn({title:"Remove all IDs",onClick:()=>{n([])}});l.appendChild(m)}const u=document.createElement("span");if(u.classList.add("neuroglancer-related-segment-list-title"),u.textContent=i,l.appendChild(u),n!==void 0){const m=qd({title:"Add related segment ID",onClick:()=>{const g=new T.O8,v=o.registerDisposer((0,T.K9)(g)),y=document.createElement("div");y.classList.add("neuroglancer-segment-list-entry"),y.classList.add("neuroglancer-segment-list-entry-new");const S=Hn({});if(S.classList.add("neuroglancer-segment-list-entry-copy"),y.appendChild(S),s!=null){const D=document.createElement("input");D.classList.add("neuroglancer-segment-list-entry-visible-checkbox"),D.type="checkbox",y.appendChild(D)}const w=Mn({title:"Cancel adding new segment ID",onClick:()=>{v()}});w.classList.add("neuroglancer-segment-list-entry-delete"),y.appendChild(w);const b=document.createElement("input");b.autocomplete="off",b.spellcheck=!1,b.classList.add("neuroglancer-segment-list-entry-id");const x=g.registerDisposer(new yn(b,WL));x.allShortcutsAreGlobal=!0;const E=()=>{const D=new P.R;if(D.tryParseString(b.value))return b.dataset.valid="true",D;b.dataset.valid="false"};E(),b.addEventListener("input",()=>{E()}),b.addEventListener("blur",()=>{const D=E();D!==void 0&&n([...e,D]),v()}),Z(b,"cancel",v),Z(b,"commit",()=>{const D=E();D!==void 0&&n([...e,D]),v()}),y.appendChild(b),a.appendChild(y),b.focus(),g.registerDisposer(()=>{b.value="",y.remove()})}});l.appendChild(m)}a.appendChild(l);const h=[],p=Vs.make(s??void 0,!1);for(const m of e){const g=p.get(m);if(h.push(g),n!==void 0){const v=Mn({title:"Remove ID",onClick:y=>{n(e.filter(S=>!P.R.equal(S,m))),y.stopPropagation()}});v.classList.add("neuroglancer-segment-list-entry-delete"),g.children[0].appendChild(v)}a.appendChild(g)}if(s!=null){const m=o.registerCancellable((0,Qe.t)(()=>{const{visibleSegments:g}=s.segmentationGroupState.value;let v=0;for(const y of e)g.has(y)&&++v;for(const y of h)p.update(y);d.checked=v===e.length&&v>0,d.indeterminate=v>0&&v{const l=this.manager.root.selectionState.value;if(l===void 0)return;const c=l.layers.find(v=>v.layer===this)?.state;if(c===void 0)return;const{annotationId:d}=c;if(d===void 0)return;let u=this.annotationStates.states.find(v=>v.sourceIndex===c.annotationSourceIndex&&(c.annotationSubsource===void 0||v.subsourceId===c.annotationSubsource));if(u===void 0)return;let h=this.annotationStates.states.indexOf(u),{source:p}=u,m=Array.from(p),g=m.findIndex(v=>v.id===d);for(;;){if(g=g+a,g===-1)h-=1;else if(g===m.length)h+=1;else{const v=m[g];this.selectAnnotation(u,v.id,!0),uy(this,v,u);return}if(u=this.annotationStates.states[h],u===void 0)return;p=u.source,m=Array.from(p),g=g===-1?m.length:0}},this.annotationDisplayState.color.changed.add(this.specificationChanged.dispatch),this.annotationDisplayState.shader.changed.add(this.specificationChanged.dispatch),this.annotationDisplayState.shaderControls.changed.add(this.specificationChanged.dispatch),this.tabs.add("annotations",{label:"Annotations",order:10,getter:()=>new zL(this)});let s;const r=()=>{const a=this.isReady;a&&s!==void 0?(s(),s=void 0):!a&&s===void 0&&(s=this.annotationStates.markLoading())};this.readyStateChanged.add(r),r();const{mouseState:o}=this.manager.layerSelectedValues;this.registerDisposer(o.changed.add(()=>{if(o.active){const{pickedAnnotationLayer:a}=o;if(a!==void 0&&this.annotationStates.states.includes(a)){const l=this.annotationDisplayState.hoverState.value;(l===void 0||l.id!==o.pickedAnnotationId||l.partIndex!==o.pickedOffset||l.annotationLayerState!==a)&&(this.annotationDisplayState.hoverState.value={id:o.pickedAnnotationId,partIndex:o.pickedOffset,annotationLayerState:a});return}}this.annotationDisplayState.hoverState.value=void 0})),this.registerDisposer(this.registerLayerEvent("select-previous",()=>{this.changeSelectedIndex(-1)})),this.registerDisposer(this.registerLayerEvent("select-next",()=>{this.changeSelectedIndex(1)}))}initializeAnnotationLayerViewTab(n){}restoreState(n){super.restoreState(n),this.annotationDisplayState.color.restoreState(n[wy])}captureSelectionState(n,s){super.captureSelectionState(n,s);const r=s.pickedAnnotationLayer;r===void 0||!this.annotationStates.states.includes(r)||(n.annotationId=s.pickedAnnotationId,n.annotationType=s.pickedAnnotationType,n.annotationBuffer=new Uint8Array(s.pickedAnnotationBuffer,s.pickedAnnotationBufferBaseOffset),n.annotationIndex=s.pickedAnnotationIndex,n.annotationCount=s.pickedAnnotationCount,n.annotationPartIndex=s.pickedOffset,n.annotationSourceIndex=r.sourceIndex,n.annotationSubsource=r.subsourceId)}displayAnnotationState(n,s,r){if(n.annotationId===void 0)return!1;const o=this.annotationStates.states.find(l=>l.sourceIndex===n.annotationSourceIndex&&l.subsubsourceId===n.annotationSubsubsourceId&&(n.annotationSubsource===void 0||l.subsourceId===n.annotationSubsource));if(o===void 0)return!1;const a=r.registerDisposer(o.source.getReference(n.annotationId));return s.appendChild(r.registerDisposer(new Wt(r.registerDisposer(new _.wP(()=>({annotation:a,chunkTransform:o.chunkTransform}))),({annotation:l,chunkTransform:c},d,u)=>{let h;if(l==null)if(n.annotationType!==void 0&&n.annotationBuffer!==void 0){const p=Ft[n.annotationType],m=o.source.rank,g=p.serializedBytes(m),v=n.annotationBuffer.byteOffset,y=new DataView(n.annotationBuffer.buffer),S=U.LITTLE===te,{properties:w}=o.source,b=new Eh(m,g,w.value),x=n.annotationIndex,E=n.annotationCount;l=p.deserialize(y,v+b.propertyGroupBytes[0]*x,S,m,n.annotationId),b.deserialize(y,v,x,E,S,l.properties=new Array(w.value.length)),o.source.hasNonSerializedProperties()&&(h="Loading...")}else h=l===null?"Annotation not found":"Loading...";if(l!=null){const p=c.error===void 0?c.layerRank:0,m=document.createElement("div");m.classList.add("neuroglancer-selected-annotation-details-position-grid"),m.style.gridTemplateColumns=`[icon] 0fr [copy] 0fr repeat(${p}, [dim] 0fr [coord] 0fr) [move] 0fr [delete] 0fr`,d.appendChild(m);const g=Ft[l.type],v=document.createElement("div");if(v.className="neuroglancer-selected-annotation-details-icon",v.textContent=g.icon,m.appendChild(v),p!==0){const{layerDimensionNames:L}=c.modelTransform;for(let N=0;N{const O=Hn({title:"Copy position",onClick:()=>{mi(N.map(V=>Math.floor(V)).join(", "))}});O.style.gridColumn="copy",m.appendChild(O);for(let V=0;V{cy(this,c,N)}});V.style.gridColumn="move",m.appendChild(V)}})}if(!o.source.readonly){const L=Mn({title:"Delete annotation",onClick:()=>{o.source.delete(a)}});L.classList.add("neuroglancer-selected-annotation-details-delete"),m.appendChild(L)}const{relationships:y,properties:{value:S}}=o.source,w=o.source.readonly,b=document.createElement("label");b.classList.add("neuroglancer-annotation-property");const x=document.createElement("span");x.classList.add("neuroglancer-annotation-property-label"),x.textContent="ID",b.appendChild(x);const E=document.createElement("span");E.classList.add("neuroglancer-annotation-property-value"),E.textContent=a.id,b.appendChild(E),d.appendChild(b);const D=[];for(let L=0,N=S.length;L`#${O}`).join(" "),L.appendChild(k),d.appendChild(L)}const{relatedSegments:I}=l;for(let L=0,N=y.length;L{const Y=a.value;if(Y==null)return;let{relatedSegments:Q}=Y;Q===void 0?Q=o.source.relationships.map(()=>[]):Q=Q.slice(),Q[O]=z;const X={...Y,relatedSegments:Q};o.source.update(a,X),o.source.commit(a)})).element)}if(!o.source.readonly||l.description)if(o.source.readonly){const L=document.createElement("div");L.className="neuroglancer-annotation-details-description",L.textContent=l.description||"",d.appendChild(L)}else{const L=document.createElement("textarea");L.value=l.description||"",L.rows=3,L.className="neuroglancer-annotation-details-description",L.placeholder="Description",L.addEventListener("change",()=>{const N=L.value;o.source.update(a,{...l,description:N||void 0}),o.source.commit(a)}),d.appendChild(L)}}if(h!==void 0){const p=document.createElement("div");p.classList.add("neuroglancer-selection-annotation-status"),p.textContent=h,d.appendChild(p)}})).element),!0}displaySelectionState(n,s,r){let o=this.displayAnnotationState(n,s,r);return super.displaySelectionState(n,s,r)&&(o=!0),o}addLocalAnnotations(n,s,r){const{subsourceEntry:o}=n,a=new jo({localPosition:this.localPosition,transform:n.getRenderLayerTransform(),source:s,displayState:this.annotationDisplayState,dataSource:n.loadedDataSource.layerDataSource,subsourceIndex:n.subsourceIndex,subsourceId:o.id,role:r});this.addAnnotationLayerState(a,n)}addStaticAnnotations(n){const{subsourceEntry:s}=n,{staticAnnotations:r}=s.subsource;return r===void 0?!1:(n.activate(()=>{this.addLocalAnnotations(n,r,li.DEFAULT_ANNOTATION)}),!0)}addAnnotationLayerState(n,s){const r=s.activated;r.registerDisposer(this.annotationStates.add(n));const o=new RL(this.manager.chunkManager,n.addRef());if(o.source instanceof Rr){const a=new AL({annotationLayer:o.addRef(),renderScaleTarget:this.annotationCrossSectionRenderScaleTarget,renderScaleHistogram:this.annotationCrossSectionRenderScaleHistogram});r.registerDisposer(s.messages.addChild(a.messages));const l=new PL({annotationLayer:o.addRef(),renderScaleTarget:this.annotationProjectionRenderScaleTarget,renderScaleHistogram:this.annotationProjectionRenderScaleHistogram});r.registerDisposer(s.messages.addChild(l.messages)),r.registerDisposer((0,_.no)((c,d)=>{d&&(c.registerDisposer(this.addRenderLayer(a.addRef())),c.registerDisposer(this.addRenderLayer(l.addRef())))},this.annotationDisplayState.displayUnfiltered))}{const a=new ML(o,this.annotationCrossSectionRenderScaleHistogram);r.registerDisposer(this.addRenderLayer(a)),r.registerDisposer(s.messages.addChild(a.messages))}{const a=new kL(o.addRef(),this.annotationProjectionRenderScaleHistogram);r.registerDisposer(this.addRenderLayer(a)),r.registerDisposer(s.messages.addChild(a.messages))}}selectAnnotation(n,s,r){this.manager.root.selectionState.captureSingleLayerState(this,o=>(o.annotationId=s,o.annotationSourceIndex=n.sourceIndex,o.annotationSubsource=n.subsourceId,o.annotationSubsubsourceId=n.subsubsourceId,!0),r)}toJSON(){const n=super.toJSON();return n[wy]=this.annotationDisplayState.color.toJSON(),n}}return e}function xy(i,e,t,n,s,r){const o=t.chunkTransform.value,a=document.createElement("div");a.classList.add("neuroglancer-annotation-list-entry"),a.dataset.color=t.displayState.color.toString(),a.style.gridTemplateColumns=n;const l=document.createElement("div");l.className="neuroglancer-annotation-icon",l.textContent=Ft[e.type].icon,a.appendChild(l);let c;const d=()=>{t.source.readonly||c===void 0&&(c=Mn({title:"Delete annotation",onClick:g=>{g.stopPropagation(),g.preventDefault();const v=t.source.getReference(e.id);try{t.source.delete(v)}finally{v.dispose()}}}),c.classList.add("neuroglancer-annotation-list-entry-delete"),a.appendChild(c))},u=[];let h=0;if(dy(e,o,(g,v)=>{++h;const y=document.createElement("div");y.className="neuroglancer-annotation-position",a.appendChild(y);let S=0;const w=(b,x)=>{for(const E of b){const D=x[E];if(D!==-1){const I=Math.floor(g[D]),L=document.createElement("div"),N=I.toString();L.textContent=N,L.classList.add("neuroglancer-annotation-coordinate"),L.style.gridColumn=`dim ${S+1}`,u[S]=Math.max(u[S]||0,N.length),y.appendChild(L)}++S}};w(s,o.modelTransform.globalToRenderLayerDimensions),w(r,o.modelTransform.localToRenderLayerDimensions),d()}),e.description){++h;const g=document.createElement("div");g.classList.add("neuroglancer-annotation-description"),g.textContent=e.description,a.appendChild(g)}const{properties:{value:p}}=t.source,m=[];for(let g=0,v=p.length;g`#${v}`).join(" "),a.appendChild(g)}return l.style.gridRow=`span ${h}`,c!==void 0&&(c.style.gridRow=`span ${h}`),a.addEventListener("mouseenter",()=>{i.selectAnnotation(t,e.id,!1)}),a.addEventListener("action:select-position",g=>{g.stopPropagation(),i.selectAnnotation(t,e.id,"toggle")}),a.addEventListener("action:pin-annotation",g=>{g.stopPropagation(),i.selectAnnotation(t,e.id,!0)}),a.addEventListener("action:move-to-annotation",g=>{g.stopPropagation(),g.preventDefault(),uy(i,e,t)}),[a,u]}/** + * /** + * @license + * This work is a derivative of the Google Neuroglancer project, + * Copyright 2016 Google Inc. + * The Derivative Work is covered by + * Copyright 2021 Howard Hughes Medical Institute + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const eu="selectSegments",tu="mousedown0",JL=Ae.fromObject({[`at:alt?+shift?+${tu}`]:"drag-select-segments"});var jL=(i=>(i[i.IDLE=0]="IDLE",i[i.SELECT=1]="SELECT",i[i.DESELECT=2]="DESELECT",i))(jL||{});class YL extends gi{toJSON(){return eu}activate(e){const{layer:t}=this,{body:n,header:s}=Vi(e);let r=0,o=!1;e.bindInputEventMap(JL);const a=()=>Vo.value&sf.ALT?2:1,l=h=>{r!==h&&(r=h,o=!1,c())},c=()=>{Me(n);const h=document.createElement("span");switch(r){case 0:s.textContent="Select/Deselect segments",h.textContent=`${tu} to select segments; alt+${tu} to deselect segments.`;break;case 1:case 2:s.textContent=`${r===1?"Select":"Deselect"} segments`,h.textContent=`Drag to ${r===1?"select":"deselect"} segments (${t.displayState.segmentationGroupState.value.visibleSegments.size} selected).`}n.appendChild(h)};c();const d=()=>{if(r===0)return;const{segmentSelectionState:h}=t.displayState;if(h.hasSelectedSegment){const p=h.selectedSegment,{selectedSegments:m,visibleSegments:g}=t.displayState.segmentationGroupState.value;switch(r){case 1:m.add(p),g.add(p);break;case 2:m.delete(p);break}}};e.registerDisposer(t.displayState.segmentSelectionState.changed.add(()=>{o&&d()})),e.registerDisposer(t.displayState.segmentationGroupState.value.visibleSegments.changed.add(c)),e.registerDisposer(Vo.changed.add(()=>{r!==0&&l(a())}));const u=(h,p)=>{h.stopPropagation(),l(p),d();const m=h.detail.screenX,g=h.detail.screenY;zt(h.detail,(v,y,S)=>{if(!o){const w=v.screenX-m,b=v.screenY-g;w*w+b*b>25&&(d(),o=!0)}},v=>{o=!1,l(0)})};e.bindAction("drag-select-segments",h=>u(h,a()))}get description(){return"select"}}function QL(i){sn(i,eu,e=>new YL(e))}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const nu="mergeSegments",iu="splitSegments",KL=Ae.fromObject({"at:shift?+mousedown0":{action:"merge-segments"},"at:shift?+mousedown2":{action:"set-anchor"}}),qL=Ae.fromObject({"at:shift?+mousedown0":{action:"split-segments"},"at:shift?+alt+mousedown0":{action:"split-and-select-segments"},"at:shift?+mousedown2":{action:"set-anchor"}});class XL extends gi{constructor(e){super(e),this.lastAnchorBaseSegment=new _.B0(void 0);const t=()=>{const n=e.anchorSegment.value;if(n===void 0)return;const{segmentSelectionState:s}=e.displayState;if(!s.hasSelectedSegment)return;const{segmentEquivalences:r}=e.displayState.segmentationGroupState.value,o=r.get(n);if(!P.R.equal(s.selectedSegment,o))return;const a=s.baseSelectedSegment,l=(0,Rt.YR)(a),c=r.disjointSets.visibleSegmentEquivalencePolicy.value;c&Rt.y6.NONREPRESENTATIVE_EXCLUDED&&l||c&Rt.y6.REPRESENTATIVE_EXCLUDED&&!l||(this.lastAnchorBaseSegment.value=a.clone())};this.registerDisposer(e.displayState.segmentSelectionState.changed.add(t)),this.registerDisposer(e.anchorSegment.changed.add(t))}toJSON(){return nu}activate(e){const t=this.layer.displayState.segmentationGroupState.value,n=()=>{const c=this.layer.anchorSegment.value,d=this.lastAnchorBaseSegment.value;if(c===void 0)return{anchorSegment:void 0,error:"Select anchor segment for merge"};const u=t.segmentEquivalences.get(c);return t.visibleSegments.has(u)?d===void 0||!P.R.equal(t.segmentEquivalences.get(d),u)?{anchorSegment:c,error:"Hover over base segment within anchor segment that is closest to merge location"}:{anchorSegment:d,error:void 0}:{anchorSegment:c,error:"Anchor segment must be in visible set"}},s=()=>{const{anchorSegment:c,error:d}=n();if(c===void 0||d!==void 0)return{anchorSegment:c,error:d,otherSegment:void 0,anchorSegmentValid:!1};const{displayState:u}=this.layer,h=u.segmentSelectionState.baseValue;return h===void 0||P.R.equal(u.segmentSelectionState.selectedSegment,t.segmentEquivalences.get(c))?{anchorSegment:c,otherSegment:void 0,error:"Hover over segment to merge",anchorSegmentValid:!0}:{anchorSegment:c,otherSegment:h,error:void 0,anchorSegmentValid:!0}},{body:r,header:o}=Vi(e);o.textContent="Merge segments",r.classList.add("neuroglancer-merge-segments-status"),e.bindInputEventMap(KL),e.registerDisposer(()=>{Ur(t)});const a=()=>{Me(r);const{displayState:c}=this.layer,{anchorSegment:d,otherSegment:u,anchorSegmentValid:h,error:p}=s(),m=y=>{const S=Id(this.layer.displayState,y);return S.classList.add("neuroglancer-segment-list-entry-double-line"),S};if(d!==void 0&&r.appendChild(m(Yi(c,d))),p!==void 0){const y=document.createElement("span");y.textContent=p,r.appendChild(y)}if(u!==void 0){const y=document.createElement("span");y.textContent=" merge ",r.appendChild(y),r.appendChild(m(Yi(c,u)))}const{segmentEquivalences:g}=t;if(!h){Ur(t);return}t.useTemporaryVisibleSegments.value=!0;const v=t.temporaryVisibleSegments;v.clear(),v.add(g.get(d)),u!==void 0&&v.add(g.get(u))};a(),e.registerDisposer($r(this.layer.displayState,r));const l=e.registerCancellable((0,Qe.t)(a));Bs(this.layer.displayState,e,l),e.registerDisposer(this.layer.anchorSegment.changed.add(l)),e.registerDisposer(this.lastAnchorBaseSegment.changed.add(l)),e.bindAction("merge-segments",c=>{c.stopPropagation(),(async()=>{const{graph:{value:d}}=t;if(d===void 0)return;const{anchorSegment:u,otherSegment:h,error:p}=s();if(!(u===void 0||h===void 0||p!==void 0))try{await d.merge(u,h),pe.showTemporaryMessage("Merge performed")}catch(m){pe.showTemporaryMessage(`Merge failed: ${m}`)}})()}),e.bindAction("set-anchor",c=>{c.stopPropagation();const{segmentSelectionState:d}=this.layer.displayState,u=d.baseValue;if(u===void 0)return;const h=this.layer.anchorSegment.value;if(t.visibleSegments.add(u),h===void 0||!P.R.equal(h,u)){this.layer.anchorSegment.value=u.clone();return}})}get description(){return"merge"}}class ZL extends gi{toJSON(){return iu}activate(e){const t=this.layer.displayState.segmentationGroupState.value,n=()=>{const d=this.layer.anchorSegment.value;if(d===void 0)return{anchorSegment:void 0,error:"Select anchor segment for split"};const u=t.segmentEquivalences.get(d);return t.visibleSegments.has(u)?{anchorSegment:d,error:void 0}:{anchorSegment:d,error:"Anchor segment must be in visible set"}},{body:s,header:r}=Vi(e);r.textContent="Split segments",s.classList.add("neuroglancer-merge-segments-status"),e.bindInputEventMap(qL);const o=()=>{const{anchorSegment:d,error:u}=n();if(d===void 0||u!==void 0)return{anchorSegment:d,error:u,otherSegment:void 0,anchorSegmentValid:!1};const{displayState:h}=this.layer,p=h.segmentSelectionState.baseValue;return p===void 0||!P.R.equal(h.segmentSelectionState.selectedSegment,t.segmentEquivalences.get(d))||P.R.equal(p,d)?{anchorSegment:d,otherSegment:void 0,anchorSegmentValid:!0,error:"Hover over base segment to seed split"}:{anchorSegment:d,otherSegment:p,anchorSegmentValid:!0,error:void 0}};e.registerDisposer(()=>{Ur(t)});const a=()=>{Me(s);const{displayState:d}=this.layer,{anchorSegment:u,otherSegment:h,anchorSegmentValid:p,error:m}=o();let g,v;(()=>{const{segmentEquivalences:w}=t,{graphConnection:{value:b}}=this.layer;if(!p||b===void 0){Ur(t);return}if(t.useTemporaryVisibleSegments.value=!0,h!==void 0){const E=b.computeSplit(u,h);if(E!==void 0){g=new wi(u,E.includeRepresentative),v=new wi(h,E.excludeRepresentative),t.useTemporarySegmentEquivalences.value=!0;const D=E.includeRepresentative,I=E.excludeRepresentative,L=t.temporarySegmentEquivalences;L.clear();for(const k of E.includeBaseSegments)L.link(k,D);for(const k of E.excludeBaseSegments)L.link(k,I);const N=t.temporaryVisibleSegments;N.clear(),N.add(D),N.add(I);return}}t.useTemporarySegmentEquivalences.value=!1;const x=t.temporaryVisibleSegments;x.clear(),x.add(w.get(u))})();const S=w=>{const b=Id(this.layer.displayState,w);return b.classList.add("neuroglancer-segment-list-entry-double-line"),b};if(u!==void 0&&s.appendChild(S(g??Yi(d,u))),m!==void 0){const w=document.createElement("span");w.textContent=m,s.appendChild(w)}if(v!==void 0){const w=document.createElement("span");w.textContent=" split ",s.appendChild(w),s.appendChild(S(v))}};e.registerDisposer($r(this.layer.displayState,s)),a();const l=e.registerCancellable((0,Qe.t)(a));Bs(this.layer.displayState,e,l),e.registerDisposer(this.layer.anchorSegment.changed.add(l));const c=async d=>{const{graph:{value:u}}=t;if(u===void 0)return;const{anchorSegment:h,otherSegment:p,error:m}=o();if(!(h===void 0||p===void 0||m!==void 0))try{await u.split(h,p),d&&t.visibleSegments.add(t.segmentEquivalences.get(p)),pe.showTemporaryMessage("Split performed")}catch(g){pe.showTemporaryMessage(`Split failed: ${g}`)}};e.bindAction("split-segments",d=>{d.stopPropagation(),c(!1)}),e.bindAction("split-and-select-segments",d=>{d.stopPropagation(),c(!0)}),e.bindAction("set-anchor",d=>{d.stopPropagation();const{segmentSelectionState:u}=this.layer.displayState,h=u.baseValue;if(h===void 0)return;t.visibleSegments.add(h);const p=this.layer.anchorSegment.value;if(p===void 0||!P.R.equal(p,h)){this.layer.anchorSegment.value=h.clone();return}})}get description(){return"split"}}function eR(i){sn(i,nu,e=>new XL(e)),sn(i,iu,e=>new ZL(e))}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const tR=new P.R;class Ey extends T.O8{constructor(e,t){super(),this.segmentationDisplayState=e,this.parentElement=t,this.changed=new j.HN,this.explicitSegmentsVisible=!1,this.debouncedUpdate=(0,Fe.A)(()=>this.update(),0)}updateRendering(e){this.segmentWidgetFactory.update(e)}updateRenderedItems(e){e.forEachRenderedItem(t=>{this.updateRendering(t)})}}class Ty extends Ey{constructor(e,t){super(e,t),this.segmentationDisplayState=e,this.parentElement=t,this.render=n=>{const{explicitSegments:s}=this,r=s[n];return this.segmentWidgetFactory.get(r)},this.update(),this.registerDisposer(e.segmentationGroupState.value.selectedSegments.changed.add(this.debouncedUpdate))}update(){const e=[],{selectedSegments:t}=this.segmentationDisplayState.segmentationGroupState.value,n=[...t],{explicitSegments:s}=this;s===void 0?e.push({retainCount:0,insertCount:n.length,deleteCount:0}):e.push(...(0,F.ak)(s,n,P.R.equal)),this.explicitSegments=n,this.length=n.length,this.changed.dispatch(e)}}class Dy extends Ey{constructor(e,t,n,s){super(n,s),this.query=e,this.segmentPropertyMap=t,this.segmentationDisplayState=n,this.parentElement=s,this.queryResult=new _.B0(void 0),this.prevQueryResult=new _.B0(void 0),this.statusText=new _.B0(""),this.selectedMatches=0,this.visibleMatches=0,this.matchStatusTextPrefix="",this.selectedSegmentsGeneration=-1,this.visibleSegmentsGeneration=-1,this.explicitSegmentsVisible=!1,this.render=r=>{const{explicitSegments:o}=this;let a;if(o!==void 0)a=o[r];else{a=tR;const l=this.queryResult.value.indices[r],{ids:c}=this.segmentPropertyMap.segmentPropertyMap.inlineProperties;a.low=c[l*2],a.high=c[l*2+1]}return this.segmentWidgetFactory.get(a)},this.update(),this.registerDisposer(n.segmentationGroupState.value.selectedSegments.changed.add(this.debouncedUpdate)),this.registerDisposer(n.segmentationGroupState.value.visibleSegments.changed.add(this.debouncedUpdate)),e&&this.registerDisposer(e.changed.add(this.debouncedUpdate))}get numMatches(){return this.queryResult.value?.count??0}update(){const e=this.query.value,{segmentPropertyMap:t}=this;this.prevQueryResult.value=this.queryResult.value;const n=this.prevQueryResult.value;let s;if(this.prevQuery===e)s=n;else{const b=mI(t,e);s=vI(t,b)}const r=[];let o=!1,a="";const l=xI(s.query);l||this.explicitSegments!==void 0&&this.explicitSegmentsVisible&&(r.push({deleteCount:this.explicitSegments.length,retainCount:0,insertCount:0}),this.explicitSegments=void 0,o=!0);const{explicitIds:c}=s;c!==void 0?this.explicitSegments=c:this.explicitSegmentsVisible||(this.explicitSegments=void 0),n!==s&&(r.push({retainCount:0,deleteCount:n?.count??0,insertCount:s.count}),o=!0,this.queryResult.value=s),s.explicitIds!==void 0?a=`${s.count} ids`:l?a=`${s.count} total ids`:s.total>0&&(a=`${s.count} match /${s.total} total ids`);const{selectedSegments:d,visibleSegments:u}=this.segmentationDisplayState.segmentationGroupState.value,h=d.changed.count,p=u.changed.count,m=this.selectedSegmentsGeneration,g=this.visibleSegmentsGeneration,v=n!==s,y=m!==h||v,S=g!==p||v;this.selectedSegmentsGeneration=h,this.visibleSegmentsGeneration=p,y&&(this.selectedMatches=s.count>0?cv(t,s,d):0),S&&(this.visibleMatches=s.count>0?cv(t,s,u):0);let w=a;this.selectedMatches>0&&(this.selectedMatches===this.visibleMatches?w=`${this.selectedMatches} vis/${w}`:this.visibleMatches>0?w=`${this.visibleMatches} vis/${this.selectedMatches} star/${w}`:w=`${this.selectedMatches} star/${w}`),this.statusText.value=w,this.prevQuery=e,this.matchStatusTextPrefix=a,this.length=s.count,o&&this.changed.dispatch(r)}}const Iy=Ae.fromObject({enter:{action:"toggle-listed"},"shift+enter":{action:"hide-listed"},"control+enter":{action:"hide-all"},escape:{action:"cancel"}});function Ly(i){$t(i,Math.max(1,i.value.length+.1))}function su(i,e){let t;if(Number.isInteger(e))t=e.toString();else{const n=e.toString(),s=e.toPrecision(6);t=n.length{t.select()}),t.classList.add(`neuroglancer-segment-query-result-numerical-plot-${i}-bound`),t.classList.add("neuroglancer-segment-query-result-numerical-plot-bound"),t.type="text",t.spellcheck=!1,t.autocomplete="off",t.title=(e===0?"Lower":"Upper")+" bound "+(i==="range"?"range":"for distribution"),t.addEventListener("input",()=>{Ly(t)}),t}function iR(i,e,t){if(i===void 0||i.indices===void 0)return;const n=i.query;let{sortBy:s,includeColumns:r}=n;Pa(n,t)?(s=s.filter(a=>a.fieldId!==t),r=r.filter(a=>a!==t)):r.push(t),e({...n,sortBy:s,includeColumns:r})}function Ry(i,e,t){const n=i?.query,s=n?.sortBy;if(s===void 0)return;const{includeColumns:r}=n,a=s.find(c=>c.fieldId===t)?.order==="<"?">":"<",l=r.filter(c=>c!==t);for(const c of s)c.fieldId!=="id"&&c.fieldId!=="label"&&c.fieldId!==t&&l.push(c.fieldId);e({...n,sortBy:[{fieldId:t,order:a}],includeColumns:l})}function ky(i,e,t){const s=i?.query?.sortBy?.find(r=>r.fieldId===t)?.order;e.textContent=s===">"?"\u25BC":"\u25B2",e.style.visibility=s===void 0?"":"visible",e.title=`Sort by ${t} in ${s==="<"?"descending":"ascending"} order`}class sR extends T.O8{constructor(e,t,n){super(),this.segmentPropertyMap=e,this.queryResult=t,this.setQuery=n,this.propertyHistograms=[],this.bounds={window:new _.B0([]),range:new _.B0([])},this.throttledUpdate=this.registerCancellable((0,la.A)(()=>this.updateHistograms(),100)),this.debouncedRender=this.registerCancellable((0,Qe.t)(()=>this.updateHistogramRenderings())),this.debouncedSetQuery=this.registerCancellable((0,Fe.A)(()=>this.setQueryFromBounds(),200));const s=e?.numericalProperties,r=[];let o;if(s!==void 0&&s.length>0){o=document.createElement("details");const a=document.createElement("summary");a.textContent=`${s.length} numerical propert${s.length>1?"ies":"y"}`,o.appendChild(a),o.classList.add("neuroglancer-segment-query-result-numerical-list");const l=this.bounds.window.value;for(let c=0,d=s.length;c{this.handleNewQueryResult()})),this.registerDisposer(this.bounds.window.changed.add(this.throttledUpdate)),this.registerDisposer(this.bounds.window.changed.add(this.debouncedRender)),this.registerDisposer(this.bounds.range.changed.add(this.debouncedRender)),this.registerDisposer(this.bounds.range.changed.add(this.debouncedSetQuery)),this.handleNewQueryResult()}setQueryFromBounds(){const e=this.queryResult.value;if(e===void 0||e.indices===void 0)return;const t=e.query,n=[],s=this.bounds.range.value,{properties:r}=this;for(let o=0,a=r.length;o0&&(s=[s[1],s[0]]);const r=Ze(n.bounds,t.window),o=this.getBounds(e),{dataType:a}=this.properties[e].property;Bt(a,r,o.window)||(this.bounds.window.value[e]=r,this.bounds.window.changed.dispatch()),Bt(a,s,o.range)||(this.bounds.range.value[e]=s,this.bounds.range.changed.dispatch())}setBound(e,t,n,s){const o=this.segmentPropertyMap.numericalProperties[n].bounds;s=Pe(o,s);const a=this.getBounds(n),l=Sr(a,e,t,s,!0);this.setBounds(n,l)}handleNewQueryResult(){const e=this.queryResult.value,{listElement:t}=this;if(t!==void 0){if(e?.indices!==void 0){const{numericalConstraints:n}=e.query,{numericalProperties:s}=this.segmentPropertyMap,r=this.bounds.range.value,o=n.length,a=s.length;r.length=a;for(let l=0;lu.id===c.fieldId);r[d]=c.bounds}}this.updateHistograms(),this.throttledUpdate.cancel()}}updateHistograms(){const e=this.queryResult.value,{listElement:t}=this;t!==void 0&&(SI(this.segmentPropertyMap,e,this.propertyHistograms,this.bounds.window.value),this.updateHistogramRenderings())}updateHistogramRenderings(){this.debouncedRender.cancel();const{listElement:e}=this;if(e===void 0)return;const{propertyHistograms:t}=this;if(t.length===0){e.style.display="none";return}e.style.display="";const{properties:n}=this;for(let s=0,r=n.length;sthis.getBounds(e),d=>this.setBounds(e,d)),o=document.createElement("span");o.classList.add("neuroglancer-segment-query-result-numerical-plot-sort");const a=document.createElement("input");a.type="checkbox",a.addEventListener("click",()=>{iR(this.queryResult.value,this.setQuery,t.id)});const l=d=>{const u=document.createElement("div");u.classList.add("neuroglancer-segment-query-result-numerical-plot-bounds"),u.classList.add(`neuroglancer-segment-query-result-numerical-plot-bounds-${d}`);const h=g=>{const v=nR(d,g);return v.addEventListener("change",()=>{if(this.bounds[d].value[e]!==void 0){try{const S=qt(t.dataType,v.value);this.setBound(d,g,e,S),this.bounds[d].changed.dispatch()}catch{}su(v,this.bounds[d].value[e][g])}}),v},p=[h(0),h(1)];let m;if(d==="range"){m=[document.createElement("div"),document.createElement("div"),document.createElement("div")],m[1].classList.add("neuroglancer-segment-query-result-numerical-plot-bound-constraint-spacer"),m[1].appendChild(a);const g=document.createElement("span");g.classList.add("neuroglancer-segment-query-result-numerical-plot-label"),g.appendChild(document.createTextNode(t.id)),g.appendChild(o),g.addEventListener("click",()=>{Ry(this.queryResult.value,this.setQuery,t.id)}),m[1].appendChild(g);const{description:v}=t;v&&(m[1].title=v),u.appendChild(m[0]),u.appendChild(p[0]);const y=document.createElement("div");y.textContent="\u2264",y.classList.add("neuroglancer-segment-query-result-numerical-plot-bound-constraint-symbol"),u.appendChild(y),u.appendChild(m[1]);const S=document.createElement("div");S.textContent="\u2264",S.classList.add("neuroglancer-segment-query-result-numerical-plot-bound-constraint-symbol"),u.appendChild(S),u.appendChild(p[1]),u.appendChild(m[2])}else u.appendChild(p[0]),u.appendChild(p[1]);return{container:u,spacers:m,inputs:p}},c={range:l("range"),window:l("window")};return n.appendChild(c.range.container),n.appendChild(s),n.appendChild(c.window.container),{property:t,controller:r,element:n,plotImg:s,boundElements:c,bounds:{window:[NaN,NaN],range:[NaN,NaN]},propertyHistogram:void 0,columnCheckbox:a,sortIcon:o}}updateNumericalPropertySummary(e,t,n){const s=t.bounds.window,r=this.bounds.window.value[e],o=t.bounds.range,a=this.bounds.range.value[e],{property:l}=t,c=this.queryResult.value,d=Pa(c?.query,l.id);if(t.columnCheckbox.checked=d,t.columnCheckbox.title=d?"Remove column from result table":"Add column to result table",ky(c,t.sortIcon,l.id),t.propertyHistogram===n&&Bt(l.dataType,s,r)&&Bt(l.dataType,o,a))return;const{histogram:u}=n,h="http://www.w3.org/2000/svg",p=document.createElementNS(h,"svg");p.setAttribute("width","1"),p.setAttribute("height","1"),p.setAttribute("preserveAspectRatio","none");const m=document.createElementNS(h,"rect"),g=re(r,a[0]),v=re(r,a[1]);m.setAttribute("x",`${g}`),m.setAttribute("y","0"),m.setAttribute("width",`${v-g}`),m.setAttribute("height","1"),m.setAttribute("fill","#4f4f4f"),p.appendChild(m);const y=u.length,S=(L,N,k)=>{const O=document.createElementNS(h,"polyline");let V="",z=0;for(let oe=L;oe{const Ke=oe/(y-2),$e=Y*(1-Ke)+Q*Ke;V+=` ${$e},${1-Se}`};L!==0&&X(L,0);let ce=0;for(let oe=L;oe{e(dv(n,r,!0,!d&&!u))}),c.title=h;const p=d||u,m=v=>{const y=v?o:i.count-o,S=document.createElement("div");if(S.classList.add("neuroglancer-segment-query-result-tag-toggle"),S.classList.add(`neuroglancer-segment-query-result-tag-${v?"include":"exclude"}`),l.appendChild(S),!p&&y===0)return;const w=v?d:u;S.appendChild(new rn({get value(){return w},set value(b){e(dv(n,r,v,b))},changed:j.$$},{text:v?"+":"-",enableTitle:`Add tag to ${v?"required":"exclusion"} set`,disableTitle:`Remove tag from ${v?"required":"exclusion"} set`,backgroundScheme:"dark"}).element)};m(!0),m(!1),l.appendChild(c);const g=document.createElement("span");g.classList.add("neuroglancer-segment-query-result-tag-count"),p||(g.textContent=o.toString()),l.appendChild(g)}return s}class Py extends T.O8{constructor(e,t){super(),this.listSource=e,this.group=t,this.element=document.createElement("div"),this.selectionStatusContainer=document.createElement("span"),this.selectionStatusMessage=document.createElement("span"),this.statusChanged=new j.IY,this.debouncedUpdateStatus=(0,Fe.A)(()=>this.updateStatus(),0);const{element:n}=this;n.style.display="contents",this.starAllButton=Bm({title:"Click to toggle star status, shift+click to unstar non-visible segments.",onClick:r=>{const o=this.starAllButton.classList.contains("neuroglancer-starred");if(r.shiftKey){const a=[];for(const l of this.group.selectedSegments)this.group.visibleSegments.has(l)||a.push(l);this.group.selectedSegments.delete(a);return}this.selectSegments(!o,!1)}}),this.copyAllSegmentsButton=Hn({title:"Copy all segment IDs",onClick:()=>{this.copySegments(!1)}}),this.copyVisibleSegmentsButton=Hn({title:"Copy visible segment IDs",onClick:()=>{this.copySegments(!0)}}),this.visibilityToggleAllButton=Vm({onClick:r=>{if(r.shiftKey){this.invertVisibility();return}this.makeSegmentsVisible(!this.visibilityToggleAllButton.classList.contains("neuroglancer-visible"))}});const{selectionStatusContainer:s}=this;this.selectionStatusMessage.classList.add("neuroglancer-segment-list-status-message"),s.classList.add("neuroglancer-segment-list-status"),s.appendChild(this.copyAllSegmentsButton),s.appendChild(this.starAllButton),s.appendChild(this.visibilityToggleAllButton),s.appendChild(this.copyVisibleSegmentsButton),s.appendChild(this.selectionStatusMessage),this.element.appendChild(s),this.registerDisposer(t.visibleSegments.changed.add(this.debouncedUpdateStatus)),this.registerDisposer(t.selectedSegments.changed.add(this.debouncedUpdateStatus)),this.registerDisposer(e.changed.add(this.debouncedUpdateStatus))}makeSegmentsVisible(e){const{visibleSegments:t}=this.group,n=Array.from(this.listSegments(!0));t.set(n,e)}invertVisibility(){const e=[],t=[],{visibleSegments:n}=this.group;for(const s of this.listSegments(!0))n.has(s)?t.push(s):e.push(s);n.set(e,!0),n.set(t,!1)}selectSegments(e,t=!1){const{selectedSegments:n,visibleSegments:s}=this.group,r=Array.from(this.listSegments(!0));(e||!t)&&n.set(r,e),t&&s.set(r,e)}copySegments(e=!1){let t=[...this.listSegments(!0)];e&&(t=t.filter(n=>this.group.visibleSegments.has(n))),t.sort(P.R.compare),mi(t.join(", "))}*listSegments(e=!1){}updateStatus(){const{listSource:e,group:t,starAllButton:n,selectionStatusMessage:s,copyAllSegmentsButton:r,copyVisibleSegmentsButton:o,visibilityToggleAllButton:a}=this;e.debouncedUpdate.flush();const{visibleSegments:l,selectedSegments:c}=t;let d=0,u=0,h=0,p="";const m=c.size,g=l.size;e instanceof Dy?(h=e.numMatches,d=e.visibleMatches,u=e.selectedMatches,p=e.statusText.value):p=`${g}/${m} visible`;const v=h?d:g,y=h?u:m,S=h||m;n.classList.toggle("neuroglancer-starred",y===S),n.classList.toggle("neuroglancer-indeterminate",y>0&&y!==S),s.textContent=p,r.title=`Copy all ${S} ${h?"matching":"starred"} segment(s)`,o.title=`Copy ${v} ${h?"visible matching":"visible"} segment(s)`,r.style.visibility=S?"visible":"hidden",o.style.visibility=v?"visible":"hidden",n.style.visibility=S?"visible":"hidden",a.style.visibility=S?"visible":"hidden";const w=v===S;a.classList.toggle("neuroglancer-visible",w);const b=v>0&&v!==S;a.classList.toggle("neuroglancer-indeterminate",b);let x;w?x=`Click to hide ${S} segment ID(s).`:x=`Click to show ${S-v} segment ID(s).`,b&&(x+=" Shift+click to invert visibility."),a.title=x,this.statusChanged.dispatch()}}class oR extends Py{constructor(e,t){super(e,t),this.listSource=e,this.group=t}listSegments(e=!1){return this.group.selectedSegments[Symbol.iterator]()}}class aR extends Py{constructor(e,t,n,s,r,o,a){super(t,n),this.listSource=t,this.segmentPropertyMap=s,this.debouncedUpdateQueryModel=a;const l=g=>{o.focus(),o.select();const v=bI(s,g);document.execCommand("insertText",!1,v),r.value=v,o.select()},c=document.createElement("div");c.classList.add("neuroglancer-segment-query-result-statistics");const d=document.createElement("div");d.classList.add("neuroglancer-segment-query-result-statistics-separator");const u=document.createElement("ul");u.classList.add("neuroglancer-segment-query-errors"),this.element.prepend(u,c,d),this.registerEventListener(o,"input",()=>{a()}),this.registerDisposer(Z(o,"cancel",()=>{o.focus(),o.select(),document.execCommand("delete"),o.blur(),o.value="",r.value=""})),this.registerDisposer(Z(o,"toggle-listed",()=>{this.toggleMatches()})),this.registerDisposer(Z(o,"hide-all",()=>{n.visibleSegments.clear()})),this.registerDisposer(Z(o,"hide-listed",()=>{a(),a.flush(),t.debouncedUpdate.flush();const{visibleSegments:g}=n;this.listSource instanceof Ty?g.clear():g.delete(Array.from(this.listSegments()))}));const h=this.registerDisposer(new sR(s,t.queryResult,l));{const{listElement:g}=h;g!==void 0&&c.appendChild(g)}const p=g=>{const v=g?.errors;if(Me(u),v!==void 0)for(const y of v){const S=document.createElement("li");S.textContent=y.message,u.appendChild(S)}};let m;(0,_.W1)(g=>{if(t.segmentWidgetFactory=new Wm(t.segmentationDisplayState,t.parentElement,y=>Pa(g?.query,y.id)),e.scrollToTop(),Me(e.header),s!==void 0){const y=t.segmentWidgetFactory.getHeader();y.container.classList.add("neuroglancer-segment-list-header");for(const S of y.propertyLabels){const{label:w,sortIcon:b,id:x}=S;w.addEventListener("click",()=>{Ry(t.queryResult.value,l,x)}),ky(g,b,x)}e.header.appendChild(y.container)}if(p(g),d.style.display="none",m?.remove(),g===void 0)return;const{query:v}=g;v.errors!==void 0||v.ids!==void 0||(m=rR(g,l),m!==void 0&&c.appendChild(m),(h.properties.length>0||m!==void 0)&&(d.style.display=""))},t.queryResult)}updateQuery(){const{listSource:e,debouncedUpdateQueryModel:t}=this;t(),t.flush(),e.debouncedUpdate.flush()}listSegments(e=!1){const{listSource:t,segmentPropertyMap:n}=this;this.updateQuery();const s=t.queryResult.value;return wI(n,s,e)}toggleMatches(){const{listSource:e}=this;this.updateQuery(),e.debouncedUpdate.flush();const t=e.queryResult.value;if(t===void 0)return;const{visibleMatches:n}=e,s=n!==t.count;return this.selectSegments(s,!0),!0}}class lR extends Gt{constructor(e){super(),this.layer=e;const{element:t}=this;t.classList.add("neuroglancer-segment-display-tab"),t.appendChild(this.registerDisposer(new Wt(e.displayState.segmentationGroupState.value.graph,(l,c,d)=>{if(l===void 0||l.tabContents)return;const u=document.createElement("div");u.className="neuroglancer-segmentation-toolbox",u.appendChild(Wn(d,e.toolBinder,{toolJson:nu,label:"Merge",title:"Merge segments"})),u.appendChild(Wn(d,e.toolBinder,{toolJson:iu,label:"Split",title:"Split segments"})),c.appendChild(u)})).element);const n=document.createElement("div");n.className="neuroglancer-segmentation-toolbox",n.appendChild(Wn(this,e.toolBinder,{toolJson:eu,label:"Select",title:"Select/Deselect segments"})),t.appendChild(n);const s=document.createElement("input");s.classList.add("neuroglancer-segment-list-query"),s.addEventListener("focus",()=>{s.select()});const r=this.registerDisposer(new yn(s,Iy));r.allShortcutsAreGlobal=!0;const{segmentQuery:o}=this.layer.displayState,a=this.registerCancellable((0,Fe.A)(()=>{o.value=s.value},200));s.autocomplete="off",s.title=Iy.describe(),s.spellcheck=!1,s.placeholder="Enter ID, name prefix or /regexp",this.registerDisposer((0,_.W1)(l=>{s.value=l},o)),this.registerDisposer((0,_.W1)(l=>{Date.now()-l<100&&(setTimeout(()=>{s.focus()},0),this.layer.segmentQueryFocusTime.value=Number.NEGATIVE_INFINITY)},this.layer.segmentQueryFocusTime)),t.appendChild(s),t.appendChild(this.registerDisposer(new Wt(e.displayState.segmentPropertyMap,(l,c,d)=>{const u=d.registerDisposer(new Dy(o,l,e.displayState,c)),h=d.registerDisposer(new Ty(e.displayState,c)),p=d.registerDisposer(new Wr({source:u,horizontalScroll:!0})),m=d.registerDisposer(new Wr({source:h,horizontalScroll:!0})),g=e.displayState.segmentationGroupState.value,v=d.registerDisposer(new aR(p,u,g,l,o,s,a));v.element.appendChild(p.element),c.appendChild(v.element);const y=d.registerDisposer(new oR(h,g));y.element.appendChild(m.element),c.appendChild(y.element);const S=()=>{const x=u.query.value!==""||u.numMatches>0,E=h.length>0||!x;v.element.style.display=x?"contents":"none",y.element.style.display=E?"contents":"none"};d.registerDisposer(v.statusChanged.add(S)),d.registerDisposer(y.statusChanged.add(S)),v.updateStatus(),y.updateStatus();const w=d.registerCancellable((0,Qe.t)(()=>{u.updateRenderedItems(p),h.updateRenderedItems(m)})),{displayState:b}=this.layer;Bs(b,d,w),d.registerDisposer(b.segmentationGroupState.value.selectedSegments.changed.add(w)),p.element.classList.add("neuroglancer-segment-list"),p.element.classList.add("neuroglancer-preview-list"),m.element.classList.add("neuroglancer-segment-list"),d.registerDisposer(e.bindSegmentListWidth(p.element)),d.registerDisposer(e.bindSegmentListWidth(m.element)),d.registerDisposer(new tn(p.element,Br())),d.registerDisposer(new tn(m.element,Br())),h.segmentWidgetFactory=new Wm(h.segmentationDisplayState,h.parentElement,x=>Pa(void 0,x.id)),m.scrollToTop(),Me(m.header)})).element)}}var zs=G(4472);/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class cR{constructor(){zs.A.initializeHead(this)}}const ru=new cR,dR=window.top===window,ou=(0,Fe.A)(()=>{if(!dR)return;const{activeElement:i}=document;if(i===null||i===document.body){const e=zs.A.front(ru);e!==null&&e.element.focus({preventScroll:!0})}});window.addEventListener("focus",()=>{ou()},!0),window.addEventListener("blur",()=>{ou()},!0);class za extends T.O8{constructor(e){super(),this.element=e,this.prev0=null,this.next0=null,this.lastFocusedElement=null,this.scheduleUpdateFocus=this.registerCancellable((0,Fe.A)(()=>{const{activeElement:t}=document,{element:n}=this;n.contains(t)||xc(t)||(t!=null&&(t===this.lastFocusedElement||t.contains(n))&&this.element.focus({preventScroll:!0}),this.lastFocusedElement=null)},0)),e.tabIndex=-1,this.registerEventListener(e,"pointerdown",t=>{t.target===e&&(this.lastFocusedElement=null,e.focus({preventScroll:!0}))}),this.registerEventListener(e,"mouseenter",()=>{this.lastFocusedElement=document.activeElement,this.scheduleUpdateFocus()}),this.registerEventListener(e,"mouseleave",()=>{this.scheduleUpdateFocus.cancel()}),zs.A.insertBefore(ru,this),this.registerEventListener(e,"focus",()=>{zs.A.pop(this),zs.A.insertAfter(ru,this)}),ou()}disposed(){zs.A.pop(this),super.disposed()}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const r2=100;let au=0;const uR=Ae.fromObject({escape:{action:"close"}});class Jr extends T.O8{constructor(){super(),this.keyMap=new Ae,this.keyMap.addParent(uR,Number.NEGATIVE_INFINITY),++au;const e=this.container=document.createElement("div");e.className="overlay";const t=this.content=document.createElement("div");this.registerDisposer(new za(t)),t.className="overlay-content",e.appendChild(t),document.body.appendChild(e),this.registerDisposer(new yn(this.container,this.keyMap)),this.registerEventListener(e,"action:close",()=>{this.dispose()}),t.focus()}disposed(){--au,document.body.removeChild(this.container),super.disposed()}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Wa(i={}){return Ne({text:"?",...i})}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Ay extends T.O8{constructor(e){super(),this.group=e,this.element=document.createElement("div"),this.topRow=document.createElement("div"),this.label=document.createElement("label"),this.selectElement=document.createElement("select"),this.linkedLayers=document.createElement("div"),this.unlinkButton=document.createElement("button");const{element:t,label:n,topRow:s,selectElement:r,linkedLayers:o,unlinkButton:a}=this;s.appendChild(n),s.appendChild(r),s.appendChild(a),a.textContent="Unlink",a.addEventListener("click",()=>{this.group.isolate()}),t.appendChild(s),t.appendChild(o),this.updateView();const l=(0,Fe.A)(()=>this.updateView(),0);this.registerEventListener(r,"change",()=>{this.updateModel(),l()}),this.registerDisposer(this.group.changed.add(l)),this.registerDisposer(this.group.linkedLayersChanged.add(l)),this.registerDisposer(this.group.layerManager.layersChanged.add(l))}updateModel(){const e=this.selectElement.value;e===""&&this.group.root.value!==this.group.layer?this.group.isolate():this.group.linkByName(e)}updateView(){const{selectElement:e,group:t}=this,{predicate:n}=t;Me(e);const s=this.group.rootGroup.linkedLayers.size!==0;this.unlinkButton.style.display=s?"":"none";const{linkedLayers:r}=this,o=t.linkedLayers.size!==0;if(r.style.display=o?"":"none",this.unlinkButton.textContent=o?"Unlink all":"Unlink",o){this.element.style.display="",e.style.display="none",Me(r);for(const a of t.linkedLayers){const l=document.createElement("div");l.classList.add("neuroglancer-linked-layer-widget-layer");const c=No({title:"Unlink layer",onClick:()=>{this.group.getGroup(a).isolate()}});l.appendChild(c),l.appendChild(document.createTextNode(a.managedLayer.name)),r.appendChild(l)}}else{e.style.display="";const a=document.createElement("option");e.appendChild(a);let l=0;for(const c of this.group.layerManager.managedLayers){const d=c.layer;if(d!==null&&d!==t.layer&&n(d)){++l;const u=document.createElement("option"),{name:h}=c;u.textContent=h,u.value=h,e.appendChild(u)}}e.value=t.toJSON()??"",this.element.style.display=l===0?"none":""}}}var hR=G(4138);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Ha(i={}){return Ne({svg:hR,...i})}var o2=G(1561),pR=G(5237),Ti=G.n(pR),fR=G(2205),gR=G.n(fR);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */gR()(Ti());const mR=500;class Ja extends T.O8{constructor(e){super(),this.state=e,this.changingValue=!1,this.debouncedValueUpdater=(0,Fe.A)(()=>{this.changingValue=!0;try{this.state.fragmentMain.value=this.textEditor.getValue()}finally{this.changingValue=!1}},mR),this.textEditor=Ti()(s=>{},{value:this.state.fragmentMain.value,mode:"glsl",gutters:["CodeMirror-lint-markers"]}),this.textEditor.on("change",()=>{this.setValidState(void 0),this.debouncedValueUpdater()}),this.registerDisposer(this.state.fragmentMain.changed.add(()=>{this.changingValue||this.textEditor.setValue(this.state.fragmentMain.value)})),this.element.classList.add("neuroglancer-shader-code-widget"),this.registerDisposer(this.state.shaderError.changed.add(()=>{this.updateErrorState()}));const{shaderControlState:t}=this.state;t!==void 0&&this.registerDisposer(t.parseErrors.changed.add(()=>{this.updateErrorState()})),this.updateErrorState();const n=new IntersectionObserver(s=>{s.some(r=>r.isIntersecting)&&this.textEditor.refresh()},{root:document.body});n.observe(this.element),this.registerDisposer(()=>n.disconnect())}get element(){return this.textEditor.getWrapperElement()}updateErrorState(){const{sourceStringNumber:e=1}=this.state,t=this.state.shaderError.value;let n;const{shaderControlState:s}=this.state;s!==void 0?n=s.parseErrors.value:n=[],t===void 0&&n.length===0?this.setValidState(void 0):t!=null||n.length!==0?(this.textEditor.setOption("lint",{getAnnotations:()=>{const r=[];for(const o of n)r.push({message:o.message,severity:"error",from:Ti().Pos(o.line)});if(t!=null)if(t.name==="ShaderCompilationError")for(const o of t.errorMessages)r.push({message:o.message,severity:"error",from:Ti().Pos(o.file===e&&o.line||0)});else t.name==="ShaderLinkError"?r.push({message:t.log,severity:"error",from:Ti().Pos(0)}):r.push({message:t.message,severity:"error",from:Ti().Pos(0)});return r}}),this.setValidState(!1)):(this.textEditor.setOption("lint",void 0),this.setValidState(!0))}setValidState(e){const{element:t}=this;t.classList.remove("invalid-input"),t.classList.remove("valid-input"),e===!0?t.classList.add("valid-input"):e===!1&&t.classList.add("invalid-input")}disposed(){this.debouncedValueUpdater.flush(),this.debouncedValueUpdater=void 0,at(this.element),this.textEditor=void 0,super.disposed()}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function vR(i){return{makeControl:(e,t,n)=>{const{watchableValue:s,channelCoordinateSpaceCombiner:r,dataType:o,defaultChannel:a,histogramSpecifications:l,legendShaderOptions:c,histogramIndex:d}=i(e);if(r!==void 0&&a.length!==0){const h=t.registerDisposer(new ui(r.combined)),p=t.registerDisposer(new xs(h,r,{copyButton:!1}));t.registerDisposer(h.changed.add(()=>{const g=h.value,v=Array.from(g,S=>Math.floor(S)),y=s.value;(0,F.r1)(y.channel,v)||(s.value={...s.value,channel:v})}));const m=()=>{const g=h.value,v=s.value;(0,F.r1)(g,v.channel)||(g.set(v.channel),h.changed.dispatch())};m(),t.registerDisposer(s.changed.add(m)),n.labelContainer.appendChild(p.element)}const u=t.registerDisposer(new bf(n.visibility,n.display,o,s,l,d,a.length===0?c:void 0));return{control:u,controlElement:u.element}},activateTool:(e,t)=>{Cf(e,t)}}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function yR(i){return{makeControl:(e,t,n)=>{const{watchableValue:s,properties:r,histogramSpecifications:o,legendShaderOptions:a,histogramIndex:l}=i(e);{const h=document.createElement("select");for(const[g,v]of r){const y=document.createElement("option");y.textContent=`${g} (${R[v].toLowerCase()})`,y.value=g,h.appendChild(y)}const p=()=>{const g=h.value,v=r.get(g),{window:y,range:S}=s.value;s.value={window:y!==void 0?Ce(y,v):void 0,range:S!==void 0?Ce(S,v):void 0,property:g,dataType:v}},m=()=>{h.value=s.value.property};t.registerEventListener(h,"change",p),t.registerDisposer(s.changed.add(m)),m(),n.labelContainer.appendChild(h)}const c={changed:s.changed,get value(){let{dataType:h,window:p,range:m}=s.value;return m===void 0&&(m=he[h]),{window:st(p??m),range:m}},set value(h){const{window:p,range:m}=h;s.value={...s.value,window:p,range:m}}},d=(0,_.Uq)(h=>h.dataType,[s]),u=t.registerDisposer(new Cx(n.visibility,n.display,d,c,o,l,a));return{control:u,controlElement:u.element}},activateTool:(e,t)=>{Cf(e,t)}}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function My(i,e){const{shaderControlState:t}=i,n=t.state.get(e);if(n===void 0)return;const{control:s}=n;switch(s.type){case"slider":return Yn(()=>({value:n.trackable,options:{min:s.min,max:s.max,step:s.step}}));case"color":return am(()=>n.trackable);case"checkbox":return Nr(()=>n.trackable);case"imageInvlerp":return vR(()=>({dataType:s.dataType,defaultChannel:s.default.channel,watchableValue:n.trackable,channelCoordinateSpaceCombiner:t.channelCoordinateSpaceCombiner,histogramSpecifications:t.histogramSpecifications,histogramIndex:r(),legendShaderOptions:i.legendShaderOptions}));case"propertyInvlerp":return yR(()=>({properties:s.properties,watchableValue:n.trackable,histogramSpecifications:t.histogramSpecifications,histogramIndex:r(),legendShaderOptions:i.legendShaderOptions}));case"transferFunction":return eE(()=>({dataType:s.dataType,watchableValue:n.trackable,channelCoordinateSpaceCombiner:t.channelCoordinateSpaceCombiner,defaultChannel:s.default.channel,histogramSpecifications:t.histogramSpecifications,histogramIndex:r()}))}function r(o=s.type){const a=c=>{if(o==="imageInvlerp"||o==="transferFunction")return c==="imageInvlerp"||c==="transferFunction";if(o==="propertyInvlerp")return c==="propertyInvlerp";throw new Error(`${o} does not support histogram index.`)};let l=0;for(const[c,{control:{type:d}}]of t.state){if(c===e)break;a(d)&&l++}return l}}function Ny(i,e,t){return{label:t,toolJson:SR(t,e),makeControl:(n,s,r)=>{const o=i(n);return My(o,t).makeControl(n,s,r)},activateTool:(n,s)=>{const r=i(n.tool.layer);return My(r,t).activateTool(n,s)}}}class ja extends Gt{constructor(e,t,n,s={}){super(s.visibility),this.state=e,this.display=t,this.layer=n,this.options=s,this.controlDisposer=void 0;const{toolId:r=Oy}=s;this.toolId=r;const{element:o}=this;o.style.display="contents";const{controls:a}=e;this.registerDisposer(a.changed.add(this.registerCancellable((0,Fe.A)(()=>this.updateControls(),0)))),this.updateControls()}updateControls(){const{element:e}=this;this.controlDisposer!==void 0&&(this.controlDisposer.dispose(),Me(e));const t=this.controlDisposer=new T.O8,n=()=>({shaderControlState:this.state,legendShaderOptions:this.options.legendShaderOptions});for(const s of this.state.state.keys())e.appendChild(fa(t,this.layer,this.visibility,Ny(n,this.toolId,s)))}disposed(){this.controlDisposer?.dispose(),super.disposed()}}const Oy="shaderControl",_y="control";function SR(i,e){return{type:e,[_y]:i}}class bR extends im{constructor(e,t,n,s){super(e,Ny(()=>t,n,s)),this.layerShaderControls=t,this.control=s,this.registerDisposer(t.shaderControlState.controls.changed.add(this.registerCancellable((0,Fe.A)(()=>{t.shaderControlState.state.get(s)===void 0&&this.unbind()}))))}activate(e){const{shaderControlState:t}=this.layerShaderControls;t.state.get(this.control)!==void 0&&super.activate(e)}}function Ya(i,e,t=Oy){sn(i,t,(n,s)=>{const r=(0,f.cQ)(s,_y,f.zr);return new bR(n,e(n),t,r)})}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Vy(i){return new Ja({fragmentMain:i.displayState.skeletonRenderingOptions.shader,shaderError:i.displayState.shaderError,shaderControlState:i.displayState.skeletonRenderingOptions.shaderControlState})}class CR extends Gt{constructor(e){super(),this.layer=e;const{element:t}=this;t.classList.add("neuroglancer-segmentation-rendering-tab");{const s=this.registerDisposer(new Ay(e.displayState.linkedSegmentationGroup));s.label.textContent="Linked to: ",t.appendChild(s.element)}{const s=this.registerDisposer(new Ay(e.displayState.linkedSegmentationColorGroup));s.label.textContent="Colors linked to: ",t.appendChild(s.element)}for(const s of cm)t.appendChild(fa(this,e,this.visibility,s));const n=this.registerDisposer(new Wt(e.hasSkeletonsLayer,(s,r,o)=>{if(!s)return;const a=document.createElement("div");a.className="neuroglancer-segmentation-dropdown-skeleton-shader-header";const l=document.createElement("div");l.style.flex="1",l.textContent="Skeleton shader:",a.appendChild(l),a.appendChild(Ha({title:"Show larger editor view",onClick:()=>{new wR(this.layer)}})),a.appendChild(Wa({title:"Documentation on skeleton rendering",href:"https://github.com/google/neuroglancer/blob/master/src/sliceview/image_layer_rendering.md"})),r.appendChild(a);const c=o.registerDisposer(Vy(this.layer));r.appendChild(c.element),r.appendChild(o.registerDisposer(new ja(e.displayState.skeletonRenderingOptions.shaderControlState,this.layer.manager.root.display,this.layer,{visibility:this.visibility,toolId:tm})).element),c.textEditor.refresh()},this.visibility));t.appendChild(n.element)}}class wR extends Jr{constructor(e){super(),this.layer=e,this.codeWidget=this.registerDisposer(Vy(this.layer)),this.content.classList.add("neuroglancer-segmentation-layer-skeleton-shader-overlay"),this.content.appendChild(this.codeWidget.element),this.codeWidget.textEditor.refresh()}}var xR=Object.defineProperty,ER=Object.getOwnPropertyDescriptor,TR=(i,e,t,n)=>{for(var s=n>1?void 0:n?ER(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&xR(e,t,s),s};/** + * @license + * This work is a derivative of the Google Neuroglancer project, + * Copyright 2016 Google Inc. + * The Derivative Work is covered by + * Copyright 2019 Howard Hughes Medical Institute + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */let jr=class extends vo{constructor(){super(...arguments),this.hashTable=new yd,this.changed=new j.HN}get value(){return this}static makeWithCounterpart(i){const e=new jr;return e.initializeCounterpart(i),e}set_(i,e){return this.hashTable.set(i,e)}set(i,e){if(this.set_(i,e)){const{rpc:t}=this;t&&t.invoke("Uint64Map.set",{id:this.rpcId,key:i,value:e}),this.changed.dispatch(i,!0)}}has(i){return this.hashTable.has(i)}get(i,e){return this.hashTable.get(i,e)}[Symbol.iterator](){return this.hashTable.entries()}unsafeEntries(){return this.hashTable.unsafeEntries()}delete_(i){return this.hashTable.delete(i)}delete(i){if(this.delete_(i)){const{rpc:e}=this;e&&e.invoke("Uint64Map.delete",{id:this.rpcId,key:i}),this.changed.dispatch(i,!1)}}get size(){return this.hashTable.size}assignFrom(i){this.clear();for(const[e,t]of i.unsafeEntries())this.set(e,t)}clear(){if(this.hashTable.clear()){const{rpc:i}=this;i&&i.invoke("Uint64Map.clear",{id:this.rpcId}),this.changed.dispatch(null,!1)}}toJSON(){const i={};for(const[e,t]of this.hashTable.unsafeEntries())i[e.toString()]=t.toString();return i}};jr=TR([yo("Uint64Map")],jr),pt("Uint64Map.set",function(i){const e=this.get(i.id);e.set_(i.key,i.value)&&e.changed.dispatch()}),pt("Uint64Map.delete",function(i){const e=this.get(i.id);e.delete_(i.key)&&e.changed.dispatch()}),pt("Uint64Map.clear",function(i){const e=this.get(i.id);e.hashTable.clear()&&e.changed.dispatch()});/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class DR{constructor(){this.changed=new j.HN,this.data=new Map}dispose(){this.data.clear()}get size(){return this.data.size}get value(){return this}has(e){return this.data.has(BigInt(e.toString()))}add(e){const{data:t}=this;if(Array.isArray(e)){const n=[];for(let s of e){const r=BigInt(s.toString());t.has(r)||(s=s.clone(),n.push(s),t.set(r,s))}n.length!==0&&this.changed.dispatch(n,!0)}else{const n=BigInt(e.toString());if(t.has(n))return;t.set(n,e.clone()),this.changed.dispatch(e,!0)}}[Symbol.iterator](){return this.data.values()}delete(e){const{data:t}=this;if(Array.isArray(e)){const n=[];for(const s of e){const r=BigInt(s.toString());t.has(r)&&(t.delete(r),n.push(s))}n.length!==0&&this.changed.dispatch(n,!1)}else{const n=BigInt(e.toString());if(!t.has(n))return;t.delete(n),this.changed.dispatch(e,!1)}}set(e,t){t?this.add(e):this.delete(e)}clear(){this.data.size>0&&(this.data.clear(),this.changed.dispatch(null,!1))}toJSON(){return Array.from(this.data.keys(),e=>e.toString())}assignFrom(e){this.clear();const t=e.data,{data:n}=this,s=Array.from(t.values());for(const[r,o]of t)n.set(r,o);this.changed.dispatch(s,!0)}}var IR=Object.defineProperty,LR=Object.getOwnPropertyDescriptor,RR=(i,e,t,n)=>{for(var s=n>1?void 0:n?LR(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&IR(e,t,s),s};/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */let qn=class extends vo{constructor(){super(...arguments),this.hashTable=new mm,this.changed=new j.HN}get value(){return this}static makeWithCounterpart(i){const e=new qn;return e.initializeCounterpart(i),e}set(i,e){e?this.add(i):this.delete(i)}reserve_(i){return this.hashTable.reserve(i)}reserve(i){if(this.reserve_(i)){const{rpc:e}=this;e&&e.invoke("Uint64Set.reserve",{id:this.rpcId,value:i})}}add_(i){let e=!1;for(const t of i)e=this.hashTable.add(t)||e;return e}add(i){const e=Array().concat(i);if(this.add_(e)){const{rpc:t}=this;t&&t.invoke("Uint64Set.add",{id:this.rpcId,value:e}),this.changed.dispatch(i,!0)}}has(i){return this.hashTable.has(i)}[Symbol.iterator](){return this.hashTable.keys()}unsafeKeys(){return this.hashTable.unsafeKeys()}delete_(i){let e=!1;for(const t of i)e=this.hashTable.delete(t)||e;return e}delete(i){const e=Array().concat(i);if(this.delete_(Array().concat(i))){const{rpc:t}=this;t&&t.invoke("Uint64Set.delete",{id:this.rpcId,value:e}),this.changed.dispatch(i,!1)}}get size(){return this.hashTable.size}clear(){if(this.hashTable.clear()){const{rpc:i}=this;i&&i.invoke("Uint64Set.clear",{id:this.rpcId}),this.changed.dispatch(null,!1)}}toJSON(){const i=new Array;for(const e of this.unsafeKeys())i.push(e.toString());return i.sort(),i}assignFrom(i){this.clear();for(const e of i.unsafeKeys())this.add(e)}};qn=RR([yo("Uint64Set")],qn),pt("Uint64Set.reserve",function(i){const e=this.get(i.id);e.reserve_(i.value)&&e.changed.dispatch()}),pt("Uint64Set.add",function(i){const e=this.get(i.id);e.add_(i.value)&&e.changed.dispatch()}),pt("Uint64Set.delete",function(i){const e=this.get(i.id);e.delete_(i.value)&&e.changed.dispatch()}),pt("Uint64Set.clear",function(i){const e=this.get(i.id);e.hashTable.clear()&&e.changed.dispatch()});/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class kR extends T.O8{constructor(e){super(),this.layer=e,this.specificationChanged=new j.HN,this.localGraph=new RI,this.visibleSegments=this.registerDisposer(qn.makeWithCounterpart(this.layer.manager.rpc)),this.selectedSegments=this.registerDisposer(new DR),this.segmentPropertyMap=new _.B0(void 0),this.graph=new _.B0(void 0),this.segmentEquivalences=this.registerDisposer(Ki.makeWithCounterpart(this.layer.manager.rpc,this.layer.registerDisposer((0,_.Uq)(r=>r?.visibleSegmentEquivalencePolicy||Rt.y6.MIN_REPRESENTATIVE,[this.graph])))),this.localSegmentEquivalences=!1,this.maxIdLength=new _.B0(1),this.hideSegmentZero=new nt(!0,!0),this.segmentQuery=new _.DN("",f.zr),this.temporaryVisibleSegments=this.layer.registerDisposer(qn.makeWithCounterpart(this.layer.manager.rpc)),this.temporarySegmentEquivalences=this.layer.registerDisposer(Ki.makeWithCounterpart(this.layer.manager.rpc,this.segmentEquivalences.disjointSets.visibleSegmentEquivalencePolicy)),this.useTemporaryVisibleSegments=this.layer.registerDisposer(ft.make(this.layer.manager.rpc,!1)),this.useTemporarySegmentEquivalences=this.layer.registerDisposer(ft.make(this.layer.manager.rpc,!1));const{specificationChanged:t}=this;this.hideSegmentZero.changed.add(t.dispatch),this.segmentQuery.changed.add(t.dispatch);const{visibleSegments:n,selectedSegments:s}=this;n.changed.add(t.dispatch),s.changed.add(t.dispatch),s.changed.add((r,o)=>{o||(r?n.delete(r):n.clear())}),n.changed.add((r,o)=>{o&&r&&s.add(r)})}restoreState(e){(0,f.MM)(e,od,t=>this.hideSegmentZero.restoreState(t)),(0,f.MM)(e,ha,t=>{this.localGraph.restoreState(t)}),(0,f.MM)(e,cd,t=>{const{segmentEquivalences:n,selectedSegments:s,visibleSegments:r}=this;(0,f.$v)(t,o=>{let a=String(o);const l=a.startsWith("!");l&&(a=a.substring(1));const c=P.R.parseString(a,10),d=n.get(c);s.add(d),l||r.add(d)})}),(0,f.MM)(e,qg,t=>this.segmentQuery.restoreState(t))}toJSON(){const e={};e[od]=this.hideSegmentZero.toJSON();const{selectedSegments:t,visibleSegments:n}=this;t.size>0?e[cd]=[...t].map(r=>n.has(r)?r.toString():"!"+r.toString()):e[cd]=[];const{segmentEquivalences:s}=this;return this.localSegmentEquivalences&&s.size>0&&(e[ha]=s.toJSON()),e[qg]=this.segmentQuery.toJSON(),e}assignFrom(e){this.maxIdLength.value=e.maxIdLength.value,this.hideSegmentZero.value=e.hideSegmentZero.value,this.selectedSegments.assignFrom(e.selectedSegments),this.visibleSegments.assignFrom(e.visibleSegments),this.segmentEquivalences.assignFrom(e.segmentEquivalences)}}class PR extends T.O8{constructor(e){super(),this.layer=e,this.specificationChanged=new j.HN,this.segmentColorHash=Sd.getDefault(),this.segmentStatedColors=this.registerDisposer(new jr),this.tempSegmentStatedColors2d=this.registerDisposer(new jr),this.segmentDefaultColor=new ne,this.tempSegmentDefaultColor2d=new _.B0(void 0),this.highlightColor=new _.B0(void 0);const{specificationChanged:t}=this;this.segmentColorHash.changed.add(t.dispatch),this.segmentStatedColors.changed.add(t.dispatch),this.tempSegmentStatedColors2d.changed.add(t.dispatch),this.segmentDefaultColor.changed.add(t.dispatch),this.tempSegmentDefaultColor2d.changed.add(t.dispatch),this.highlightColor.changed.add(t.dispatch)}restoreState(e){(0,f.MM)(e,dd,t=>this.segmentColorHash.restoreState(t)),(0,f.MM)(e,fd,t=>this.segmentDefaultColor.restoreState(t)),(0,f.MM)(e,Kg,t=>{const n=(0,f.vS)(t,s=>me(String(s)));for(const[s,r]of n){const o=P.R.parseString(String(s)),a=new P.R(Ie(r));this.segmentStatedColors.set(o,a)}})}toJSON(){const e={};e[dd]=this.segmentColorHash.toJSON(),e[fd]=this.segmentDefaultColor.toJSON();const{segmentStatedColors:t}=this;if(t.size>0){const n=e[Kg]={};for(const[s,r]of t.unsafeEntries())n[s.toString()]=Ge(tt(r.low))}return e}assignFrom(e){this.segmentColorHash.value=e.segmentColorHash.value,this.segmentStatedColors.assignFrom(e.segmentStatedColors),this.tempSegmentStatedColors2d.assignFrom(e.tempSegmentStatedColors2d),this.segmentDefaultColor.value=e.segmentDefaultColor.value,this.highlightColor.value=e.highlightColor.value}}class By extends T.O8{constructor(e,t){super(),this.linkedGroup=e,this.propertyName=t,this.value}get changed(){return this.linkedGroup.root.changed}get value(){const e=this.linkedGroup.root.value;if(e!==this.curRoot){this.curRoot=e;const t=e.displayState[this.propertyName];if(e===this.linkedGroup.layer){const{curGroupState:n}=this;n!==void 0&&(t.assignFrom(n),n.dispose())}this.curGroupState=t.addRef()}return this.curGroupState}disposed(){this.curGroupState?.dispose()}}class AR{constructor(e){this.layer=e,this.segmentSelectionState=new FD,this.selectedAlpha=zr(.5),this.saturation=zr(1),this.notSelectedAlpha=zr(0),this.hoverHighlight=new nt(!0,!0),this.silhouetteRendering=new _.DN(0,f.Zw,0),this.objectAlpha=zr(1),this.ignoreNullVisibleSet=new nt(!0,!0),this.skeletonRenderingOptions=new NI,this.shaderError=dr(),this.renderScaleHistogram=new Ps,this.renderScaleTarget=Bi(1),this.selectSegment=this.layer.selectSegment,this.transparentPickEnabled=this.layer.pick,this.baseSegmentColoring=new nt(!1,!1),this.baseSegmentHighlighting=new nt(!1,!1),this.useTempSegmentStatedColors2d=this.layer.registerDisposer(ft.make(this.layer.manager.rpc,!1)),this.filterBySegmentLabel=this.layer.filterBySegmentLabel,this.moveToSegment=t=>{this.layer.moveToSegment(t)},this.linkedSegmentationGroup=this.layer.registerDisposer(new Vg(this.layer.manager.rootLayers,this.layer,t=>t instanceof Ct,t=>t.displayState.linkedSegmentationGroup)),this.linkedSegmentationColorGroup=this.layer.registerDisposer(new Vg(this.layer.manager.rootLayers,this.layer,t=>t instanceof Ct,t=>t.displayState.linkedSegmentationColorGroup)),this.originalSegmentationGroupState=this.layer.registerDisposer(new kR(this.layer)),this.originalSegmentationColorGroupState=this.layer.registerDisposer(new PR(this.layer)),e.displayState=this,this.segmentationGroupState=this.layer.registerDisposer(new By(this.linkedSegmentationGroup,"originalSegmentationGroupState")),this.segmentationColorGroupState=this.layer.registerDisposer(new By(this.linkedSegmentationColorGroup,"originalSegmentationColorGroupState")),this.hideSegmentZero=this.layer.registerDisposer(new _.rG(this.segmentationGroupState,t=>t.hideSegmentZero)),this.segmentColorHash=this.layer.registerDisposer(new _.DY(this.segmentationColorGroupState,t=>t.segmentColorHash)),this.segmentStatedColors=this.layer.registerDisposer(new _.DY(this.segmentationColorGroupState,t=>t.segmentStatedColors)),this.tempSegmentStatedColors2d=this.layer.registerDisposer(new _.DY(this.segmentationColorGroupState,t=>t.tempSegmentStatedColors2d)),this.segmentDefaultColor=this.layer.registerDisposer(new _.DY(this.segmentationColorGroupState,t=>t.segmentDefaultColor)),this.tempSegmentDefaultColor2d=this.layer.registerDisposer(new _.DY(this.segmentationColorGroupState,t=>t.tempSegmentDefaultColor2d)),this.highlightColor=this.layer.registerDisposer(new _.DY(this.segmentationColorGroupState,t=>t.highlightColor)),this.segmentQuery=this.layer.registerDisposer(new _.rG(this.segmentationGroupState,t=>t.segmentQuery)),this.segmentPropertyMap=this.layer.registerDisposer(new _.rG(this.segmentationGroupState,t=>t.segmentPropertyMap))}}const MR=Zd(Rn);class Ct extends MR{constructor(e){super(e),this.sliceViewRenderScaleHistogram=new Ps,this.sliceViewRenderScaleTarget=Bi(1),this.graphConnection=new _.B0(void 0),this.segmentQueryFocusTime=new _.B0(Number.NEGATIVE_INFINITY),this.selectSegment=(n,s)=>{this.manager.root.selectionState.captureSingleLayerState(this,r=>(r.value=n.clone(),!0),s)},this.filterBySegmentLabel=n=>{const s=Yi(this.displayState,n),{label:r}=s;r&&this.filterSegments(r)},this.filterSegments=n=>{this.displayState.segmentationGroupState.value.segmentQuery.value=n,this.segmentQueryFocusTime.value=Date.now(),this.tabs.value="segments",this.manager.root.selectedLayer.layer=this.managedLayer},this.displayState=new AR(this),this.anchorSegment=new _.DN(void 0,n=>n===void 0?void 0:P.R.parseString(n)),this.has2dLayer=this.registerDisposer((0,_.ol)(n=>n.some(s=>s instanceof Vv),{changed:this.layersChanged,value:this.renderLayers})),this.has3dLayer=this.registerDisposer((0,_.ol)(n=>n.some(s=>s instanceof La||s instanceof Ad||s instanceof Ud||s instanceof wv),{changed:this.layersChanged,value:this.renderLayers})),this.hasSkeletonsLayer=this.registerDisposer((0,_.ol)(n=>n.some(s=>s instanceof Ud),{changed:this.layersChanged,value:this.renderLayers})),this.registerDisposer((0,_.aM)((n,s)=>{n.registerDisposer(s.specificationChanged.add(this.specificationChanged.dispatch)),this.specificationChanged.dispatch()},this.displayState.segmentationGroupState)),this.registerDisposer((0,_.aM)((n,s)=>{n.registerDisposer(s.specificationChanged.add(this.specificationChanged.dispatch)),this.specificationChanged.dispatch()},this.displayState.segmentationColorGroupState)),this.displayState.segmentSelectionState.bindTo(this.manager.layerSelectedValues,this),this.displayState.selectedAlpha.changed.add(this.specificationChanged.dispatch),this.displayState.saturation.changed.add(this.specificationChanged.dispatch),this.displayState.notSelectedAlpha.changed.add(this.specificationChanged.dispatch),this.displayState.objectAlpha.changed.add(this.specificationChanged.dispatch),this.displayState.hoverHighlight.changed.add(this.specificationChanged.dispatch),this.displayState.baseSegmentColoring.changed.add(this.specificationChanged.dispatch),this.displayState.ignoreNullVisibleSet.changed.add(this.specificationChanged.dispatch),this.displayState.skeletonRenderingOptions.changed.add(this.specificationChanged.dispatch),this.displayState.renderScaleTarget.changed.add(this.specificationChanged.dispatch),this.displayState.silhouetteRendering.changed.add(this.specificationChanged.dispatch),this.anchorSegment.changed.add(this.specificationChanged.dispatch),this.sliceViewRenderScaleTarget.changed.add(this.specificationChanged.dispatch),this.displayState.originalSegmentationGroupState.localGraph.changed.add(this.specificationChanged.dispatch),this.displayState.linkedSegmentationGroup.changed.add(()=>this.updateDataSubsourceActivations()),this.tabs.add("rendering",{label:"Render",order:-100,getter:()=>new CR(this)}),this.tabs.add("segments",{label:"Seg.",order:-50,getter:()=>new lR(this)});const t=this.registerDisposer((0,_.Uq)(n=>n===void 0,[this.displayState.segmentationGroupState.value.graph]));this.tabs.add("graph",{label:"Graph",order:-25,getter:()=>new EI(this),hidden:t}),this.tabs.default="rendering"}bindSegmentListWidth(e){return $r(this.displayState,e)}get volumeOptions(){return{volumeType:St.SEGMENTATION}}activateDataSubsources(e){const t=[],n=this.displayState.linkedSegmentationGroup.root.value===this;let s;for(const r of e){if(this.addStaticAnnotations(r))continue;const{volume:o,mesh:a,segmentPropertyMap:l,segmentationGraph:c,local:d}=r.subsourceEntry.subsource;if(o instanceof ln){switch(o.dataType){case R.FLOAT32:r.deactivate("Data type not compatible with segmentation layer");continue}r.activate(()=>r.addRenderLayer(new Vv(o,{...this.displayState,transform:r.getRenderLayerTransform(),renderScaleTarget:this.sliceViewRenderScaleTarget,renderScaleHistogram:this.sliceViewRenderScaleHistogram,localPosition:this.localPosition})),this.displayState.segmentationGroupState.value)}else a!==void 0?r.activate(()=>{const u={...this.displayState,transform:r.getRenderLayerTransform()};if(a instanceof Qi)r.addRenderLayer(new La(this.manager.chunkManager,a,u));else if(a instanceof Ra)r.addRenderLayer(new Ad(this.manager.chunkManager,a,u));else{const h=new OI(this.manager.chunkManager,a,u);r.addRenderLayer(new Ud(h.addRef())),r.addRenderLayer(new wv(h))}},this.displayState.segmentationGroupState.value):l!==void 0?n?(r.activate(()=>{}),t.push(l)):r.deactivate("Not supported on non-root linked segmentation layers"):c!==void 0?n?s!==void 0?r.deactivate("Only one segmentation graph is supported"):(s=c,r.activate(u=>{const h=c.connect(this);u.registerDisposer(()=>{h.dispose(),this.graphConnection.value=void 0});const p={...this.displayState,transform:r.getRenderLayerTransform()},m=h.createRenderLayers(this.manager.chunkManager,p,this.localPosition);this.graphConnection.value=h;for(const g of m)r.addRenderLayer(g)})):r.deactivate("Not supported on non-root linked segmentation layers"):d===As.equivalences?n?s!==void 0?r.deactivate("Only one segmentation graph is supported"):(s=this.displayState.originalSegmentationGroupState.localGraph,r.activate(u=>{this.graphConnection.value=u.registerDisposer(s.connect(this)),u.registerDisposer(()=>{this.graphConnection.value=void 0})})):r.deactivate("Not supported on non-root linked segmentation layers"):r.deactivate("Not compatible with segmentation layer")}this.displayState.originalSegmentationGroupState.segmentPropertyMap.value=fI(this.manager.chunkManager,t),this.displayState.originalSegmentationGroupState.graph.value=s}getLegacyDataSourceSpecifications(e,t,n,s){const r=super.getLegacyDataSourceSpecifications(e,t,n,s),o=(0,f.MM)(t,JT,l=>l===null?null:(0,f.zr)(l)),a=(0,f.MM)(t,jT,l=>l===null?null:(0,f.zr)(l));if(o!==void 0||a!==void 0)for(const l of r)l.enableDefaultSubsources=!1,l.subsources=new Map([["default",{enabled:!0}],["bounds",{enabled:!0}]]);return o!=null&&r.push(Pr(this.manager.dataSourceProviderRegistry.convertLegacyUrl({url:o,type:"mesh"}))),a!=null&&r.push(Pr(this.manager.dataSourceProviderRegistry.convertLegacyUrl({url:a,type:"skeletons"}))),t[ha]!==void 0&&s.find(l=>l.url===jc)===void 0&&r.push({url:jc,enableDefaultSubsources:!0,transform:{outputSpace:ki,sourceRank:0,transform:void 0,inputSpace:ki},subsources:new Map}),r}restoreState(e){super.restoreState(e),this.displayState.selectedAlpha.restoreState(e[td]),this.displayState.saturation.restoreState(e[sd]),this.displayState.notSelectedAlpha.restoreState(e[nd]),this.displayState.hoverHighlight.restoreState(e[rd]),this.displayState.objectAlpha.restoreState(e[id]),this.displayState.baseSegmentColoring.restoreState(e[ad]),this.displayState.silhouetteRendering.restoreState(e[pd]),this.displayState.ignoreNullVisibleSet.restoreState(e[ld]);const{skeletonRenderingOptions:t}=this.displayState;t.restoreState(e[pa]);const n=e[YT];n!==void 0&&t.shader.restoreState(n),this.displayState.renderScaleTarget.restoreState(e[ud]),this.anchorSegment.restoreState(e[em]),this.sliceViewRenderScaleTarget.restoreState(e[hd]);const s=(0,f.MM)(e,Xg,f.zr);s!==void 0&&this.displayState.linkedSegmentationGroup.linkByName(s);const r=(0,f.MM)(e,Zg,o=>o===!1?void 0:(0,f.zr)(o),s);r!==void 0&&this.displayState.linkedSegmentationColorGroup.linkByName(r),this.displayState.segmentationGroupState.value.restoreState(e),this.displayState.segmentationColorGroupState.value.restoreState(e)}toJSON(){const e=super.toJSON();e[td]=this.displayState.selectedAlpha.toJSON(),e[nd]=this.displayState.notSelectedAlpha.toJSON(),e[sd]=this.displayState.saturation.toJSON(),e[id]=this.displayState.objectAlpha.toJSON(),e[rd]=this.displayState.hoverHighlight.toJSON(),e[ad]=this.displayState.baseSegmentColoring.toJSON(),e[ld]=this.displayState.ignoreNullVisibleSet.toJSON(),e[pd]=this.displayState.silhouetteRendering.toJSON(),e[em]=this.anchorSegment.toJSON(),e[pa]=this.displayState.skeletonRenderingOptions.toJSON(),e[ud]=this.displayState.renderScaleTarget.toJSON(),e[hd]=this.sliceViewRenderScaleTarget.toJSON();const{linkedSegmentationGroup:t,linkedSegmentationColorGroup:n}=this.displayState;return e[Xg]=t.toJSON(),n.root.value!==t.root.value&&(e[Zg]=n.toJSON()??!1),e[ha]=this.displayState.originalSegmentationGroupState.localGraph.toJSON(),t.root.value===this&&Object.assign(e,this.displayState.segmentationGroupState.value.toJSON()),n.root.value===this&&Object.assign(e,this.displayState.segmentationColorGroupState.value.toJSON()),e}transformPickedValue(e){return e==null?e:Fm(this.displayState,e,!0)}handleAction(e,t){switch(e){case"recolor":{this.displayState.segmentationColorGroupState.value.segmentColorHash.randomize();break}case"clear-segments":{if(!this.pick.value)break;this.displayState.segmentationGroupState.value.visibleSegments.clear();break}case"select":case"star":{if(!this.pick.value)break;const{segmentSelectionState:n}=this.displayState;if(n.hasSelectedSegment){const s=n.selectedSegment,r=this.displayState.segmentationGroupState.value,o=e==="select"?r.visibleSegments:r.selectedSegments,a=!o.has(s);(a||t.segmentationToggleSegmentState===void 0)&&(t.segmentationToggleSegmentState=a),t.defer(()=>{t.segmentationToggleSegmentState===a&&o.set(s,a)})}break}}}selectionStateFromJson(e,t){super.selectionStateFromJson(e,t);const n=new P.R;let{value:s}=e;typeof s=="number"&&(s=s.toString()),typeof s!="string"||!n.tryParseString(s)?e.value=void 0:e.value=n}selectionStateToJson(e,t){const n=super.selectionStateToJson(e,t),{value:s}=e;return s instanceof wi?t?n.value={key:s.key.toString(),value:s.value?s.value.toString():void 0,label:s.label}:n.value=(s.value||s.key).toString():s instanceof P.R&&(n.value=s.toString()),n}displaySegmentationSelection(e,t,n){const{value:s}=e;let r;if((typeof s=="number"||typeof s=="string")&&(r=new P.R,!r.tryParseString(s.toString())))return!1;if(s instanceof P.R)r=s.clone();else if(s instanceof wi)r=s.key.clone();else return!1;const{displayState:o}=this,a=Yi(o,r),{segmentEquivalences:l,segmentPropertyMap:{value:c}}=this.displayState.segmentationGroupState.value,d=l.get(r),u=Id(this.displayState,a);if(Bs(o,n,n.redraw),n.registerDisposer($r(o,u)),u.classList.add("neuroglancer-selection-details-segment"),t.appendChild(u),c!==void 0){const{inlineProperties:h}=c.segmentPropertyMap;if(h!==void 0){const p=c.getSegmentInlineIndex(d);if(p!==-1){for(const m of h.properties)if(m.type!=="label"){if(m.type==="description"){const g=m.values[p];if(!g)continue;const v=document.createElement("div");v.classList.add("neuroglancer-selection-details-segment-description"),v.textContent=g,t.appendChild(v)}else if(m.type==="number"||m.type==="string"){const g=m.values[p];if(m.type==="number"?Number.isNaN(g):!g)continue;const v=document.createElement("div");v.classList.add("neuroglancer-selection-details-segment-property");const y=document.createElement("div");y.classList.add("neuroglancer-selection-details-segment-property-name"),y.textContent=m.id,m.description&&(y.title=m.description);const S=document.createElement("div");S.classList.add("neuroglancer-selection-details-segment-property-value"),S.textContent=g.toString(),v.appendChild(y),v.appendChild(S),t.appendChild(v)}}}}}return!0}displaySelectionState(e,t,n){let s=this.displaySegmentationSelection(e,t,n);return super.displaySelectionState(e,t,n)&&(s=!0),s}moveToSegment(e){for(const t of this.renderLayers){if(!(t instanceof Ad||t instanceof La))continue;const n=t.displayState.transform.value;if(n.error!==void 0)return;const{rank:s,globalToRenderLayerDimensions:r}=n,{globalPosition:o}=this.manager.root,a=new Float32Array(s),l=[];for(let d=0;d{if(i.mesh!==void 0)return{layerConstructor:Ct,priority:1}}),Ya(Ct,i=>({shaderControlState:i.displayState.skeletonRenderingOptions.shaderControlState}),tm),eR(Ct),QL(Ct);var NR=G(9580);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Yr(i,e=i.value){i.style.minWidth=e.length+1+"ch"}const Fy="neuroglancer-coordinate-space-transform-singleton";function Uy(i,e,t){let n;t&&(i+=.5,e+=.5),i===Number.NEGATIVE_INFINITY?n="(-\u221E,":n=`[${Math.floor(i)},`;let s;return e===Number.POSITIVE_INFINITY?s="+\u221E)":s=`${Math.floor(e)})`,{lower:n,upper:s}}const $y=Ae.fromObject({arrowup:{action:"move-up"},arrowdown:{action:"move-down"},arrowleft:{action:"move-left",preventDefault:!1},arrowright:{action:"move-right",preventDefault:!1},enter:{action:"commit"},escape:{action:"cancel"}});function Gy(){const i=document.createElement("div"),e=document.createElement("input");i.classList.add("neuroglancer-coordinate-space-transform-scale-container"),e.spellcheck=!1,e.autocomplete="off",e.size=1,e.classList.add("neuroglancer-coordinate-space-transform-scale"),i.appendChild(e);const t=document.createElement("div"),n=document.createElement("span");n.innerHTML=NR,t.appendChild(n);const s=document.createTextNode("");return t.appendChild(s),t.classList.add("neuroglancer-coordinate-space-transform-scale-suggestion"),i.appendChild(t),{cellElement:i,inputElement:e,suggestionElement:t}}function zy(i,e,t,n,s){if(e===void 0||e.scale===t&&e.unit===n)i.style.display="none";else{i.style.display="";const r=Ri(e.scale,e.unit,{elide1:!1});i.lastChild.textContent=r,i.title=`${s}${r}`}}function Wy(){const i=document.createElement("input");return i.spellcheck=!1,i.autocomplete="off",i.size=1,i.placeholder=" ",i.classList.add("neuroglancer-coordinate-space-transform-output-name"),i}function Hy(i,e,t){const n=i.map(h=>sr(h.value));if(n.includes(void 0))return!1;const s=Float64Array.from(n,h=>h.scale),r=Array.from(n,h=>h.unit),o=t.value,{scales:a,units:l,rank:c}=o;for(let h=0;hs[p]===a[p]&&r[p]===l[p]?h:Date.now()),u=Oe({valid:o.valid,rank:o.rank,scales:s,units:r,timestamps:d,ids:o.ids,names:o.names,boundingBoxes:o.boundingBoxes,coordinateArrays:o.coordinateArrays});return t.value=u,!0}function Jy(i,e,t,n){const s=new Float64Array(i.scales),r=Array.from(i.units);if(s[e]===t&&r[e]===n)return i;const o=Array.from(i.timestamps);return s[e]=t,r[e]=n,o[e]=Date.now(),{...i,scales:s,units:r,timestamps:o}}class OR extends T.O8{constructor(e,t,n){super(),this.transform=e,this.localCombiner=t,this.globalCombiner=n,this.element=document.createElement("div"),this.coefficientContainer=document.createElement("div"),this.translationContainer=document.createElement("div"),this.outputNameContainer=document.createElement("div"),this.outputScaleContainer=document.createElement("div"),this.inputNameContainer=document.createElement("div"),this.inputScaleContainer=document.createElement("div"),this.inputLowerBoundsContainer=document.createElement("div"),this.inputUpperBoundsContainer=document.createElement("div"),this.coefficientElements=[],this.inputNameElements=[],this.outputNameElements=[],this.outputScaleElements=[],this.outputScaleSuggestionElements=[],this.inputScaleSuggestionElements=[],this.inputScaleElements=[],this.inputBoundsElements=[],this.outputBoundsElements=[],this.addSourceDimensionIcon=Ne({svg:Fa,text:"S"}),this.addOutputDimensionIcon=Ne({svg:Fa,text:"V"}),this.addOutputDimensionCell=document.createElement("div"),this.addOutputDimensionInput=Wy(),this.inputScaleModified=[],this.outputScaleModified=[],this.curSourceRank=-1,this.curRank=-1,this.curTransform=void 0,this.addingSourceDimension=!1,this.resetToIdentityButton=Ne({text:"Set to identity",title:"Reset to identity transform",onClick:()=>{const{transform:L}=this,N=L.value.rank;L.transform=(0,De.DA)(Float64Array,N+1)}}),this.resetToDefaultButton=Ne({text:"Reset to default",title:"Reset to default input scales, transform, and output dimensions.",onClick:()=>{const{transform:L}=this;if(L.mutableSourceRank)return;const{defaultTransform:N}=L,{outputSpace:k}=N,O=k.ids.map(()=>fs());L.value={...N,outputSpace:{...k,ids:O}}}});const{element:s}=this,r=this.registerDisposer(new yn(s,$y));r.allShortcutsAreGlobal=!0,s.classList.add("neuroglancer-coordinate-space-transform-widget"),this.registerDisposer(new tn(s,$y));const o=(0,Qe.t)(()=>this.updateView());this.registerDisposer(e.changed.add(o));const{coefficientContainer:a,translationContainer:l,outputNameContainer:c,inputNameContainer:d,inputScaleContainer:u,inputLowerBoundsContainer:h,inputUpperBoundsContainer:p,outputScaleContainer:m,addOutputDimensionCell:g,addOutputDimensionIcon:v,addSourceDimensionIcon:y,resetToIdentityButton:S,resetToDefaultButton:w}=this;a.style.display="contents",l.style.display="contents",c.style.display="contents",d.style.display="contents",u.style.display="contents",m.style.display="contents",h.style.display="contents",p.style.display="contents";const b=document.createElement("div");b.classList.add("neuroglancer-coordinate-space-transform-widget-reset-buttons"),S.classList.add("neuroglancer-coordinate-space-transform-widget-reset-to-identity"),w.classList.add("neuroglancer-coordinate-space-transform-widget-reset-to-default"),b.appendChild(S),b.appendChild(w),s.appendChild(b);for(const[L,N]of[["source","Source dimensions"],["output","Output dimensions"],["input-lower","Lower"],["input-upper","Upper"],["input-scale","Scale"],["translation","Translation"]]){const k=document.createElement("div");k.classList.add(`neuroglancer-coordinate-space-transform-${L}-label`),k.classList.add("neuroglancer-coordinate-space-transform-label"),k.textContent=N,s.appendChild(k)}e.mutableSourceRank&&g.appendChild(y),g.appendChild(v),g.classList.add("neuroglancer-coordinate-space-transform-output-extend");const x="Embed in additional output dimension",E="Extend to additional source dimension";v.title=x,y.title=E,g.appendChild(this.addOutputDimensionInput),g.dataset.isActive="false",v.addEventListener("click",()=>{this.addingSourceDimension=!1,this.addOutputDimensionInput.title=x,this.addOutputDimensionCell.dataset.isActive="true",this.addOutputDimensionInput.focus()}),y.addEventListener("click",()=>{this.addingSourceDimension=!0,this.addOutputDimensionInput.title=E,this.addOutputDimensionCell.dataset.isActive="true",this.addOutputDimensionInput.focus()}),this.addOutputDimensionInput.addEventListener("blur",()=>{this.updateAddOutputDimensionCellStyle()}),s.appendChild(a),s.appendChild(c),s.appendChild(d),s.appendChild(u),s.appendChild(m),s.appendChild(h),s.appendChild(p),a.appendChild(l),s.addEventListener("input",L=>{const{target:N}=L;if(N instanceof HTMLInputElement){Yr(N);let k=this.inputScaleElements.indexOf(N);if(k!==-1){this.inputScaleModified[k]=!0,this.updateScaleValidity(N);return}if(k=this.outputScaleElements.indexOf(N),k!==-1){this.outputScaleModified[k]=!0,this.updateScaleValidity(N);return}if(k=this.outputNameElements.indexOf(N),k!==-1){this.updateOutputNameValidity();return}if(this.coefficientContainer.contains(N)){this.updateCoefficientValidity(N);return}}});const D=(L,N,k)=>{Z(s,L,O=>{O.stopPropagation();const V=O.target;if(!(V instanceof HTMLInputElement)||k!==0&&(V.selectionStart!==V.selectionEnd||V.selectionStart!==(k===1?V.value.length:0)))return;const z=this.getElementGridPosition(V);if(z===void 0)return;const Y=this.getElementByGridPosition(z.row+N,z.col+k);Y!==null&&(Y.focus(),O.preventDefault())})};D("move-up",-1,0),D("move-down",1,0),D("move-left",0,-1),D("move-right",0,1);const I=(L,N)=>{L.addEventListener("focusout",k=>{const{relatedTarget:O}=k;O instanceof Node&&L.contains(O)||N(k)})};I(a,()=>{this.updateModelTransform()||this.updateViewTransformCoefficients()}),I(c,()=>{this.updateModelOutputNames()||this.updateViewOutputNames()}),I(u,()=>{this.updateModelInputScales()||this.updateViewInputScales()}),I(m,()=>{this.updateModelOutputScales()||this.updateViewOutputScales()}),Z(s,"cancel",L=>{this.curTransform=void 0,this.updateView(),L.target.blur()}),Z(a,"commit",()=>{this.updateModelTransform()}),Z(c,"commit",()=>{this.updateModelOutputNames()}),Z(u,"commit",()=>{this.updateModelInputScales()}),Z(m,"commit",()=>{this.updateModelOutputScales()}),s.addEventListener("focusin",L=>{const{target:N}=L;N instanceof HTMLInputElement&&N.select()}),this.updateView()}updateWillBeDeletedAttributes(e){const{rank:t}=this.transform.value;e===void 0&&(e=new Array(t),e.fill(!1));const{coefficientElements:n,inputBoundsElements:s,inputScaleElements:r}=this;for(let o=0;ol.value),{value:{sourceRank:n,rank:s},mutableSourceRank:r}=this.transform;if(e.length!==s+1)return;const o=jl(t),a=new Array(s);a.fill(!1);for(let l=0;l<=s;++l){let c=o[l];t[l].length===0&&(r||l>=n)&&(c=!0,a[l]=!0),e[l].dataset.isValid=c.toString()}this.updateWillBeDeletedAttributes(a),this.updateAddOutputDimensionCellStyle()}updateScaleValidity(e){const t=sr(e.value)!==void 0;e.dataset.isValid=t.toString()}updateCoefficientValidity(e){const t=Number.isFinite(Number(e.value));e.dataset.isValid=t.toString()}getElementGridPosition(e){{const t=this.outputNameElements.indexOf(e);if(t!==-1)return{row:t,col:-2}}{const t=this.inputScaleElements.indexOf(e);if(t!==-1)return{row:-1,col:t}}{const t=this.coefficientElements.indexOf(e),{rank:n}=this.transform.value;if(t!==-1)return{row:t%n,col:Math.floor(t/n)}}{const t=this.outputScaleElements.indexOf(e);if(t!==-1)return{row:t,col:-1}}}getElementByGridPosition(e,t){const{rank:n}=this.transform.value;return e===-1?t<0||t>=n?null:this.inputScaleElements[t]:t===-2?e<0||e>n?null:this.outputNameElements[e]:t===-1?e<0||e>=n?null:this.outputScaleElements[e]:e<0||e>=n||t<0||t>n?null:this.coefficientElements[t*n+e]}dimensionRefCount(e){return(rr(e)?this.localCombiner:this.globalCombiner).dimensionRefCounts.get(e)||0}updateModelInputScales(){return Hy(this.inputScaleElements,this.inputScaleModified,this.transform.inputSpace)}updateModelOutputScales(){return Hy(this.outputScaleElements,this.outputScaleModified,this.transform.outputSpace)}updateModelOutputNames(){const e=this.outputNameElements.map(S=>S.value),{value:t,mutableSourceRank:n}=this.transform,{outputSpace:s,rank:r,sourceRank:o}=t;if(e.length!==r+1)return;const a=[],l=[],c=e[r].length!==0;let d=o;for(let S=0;S<=r;++S){const w=e[S];if(w.length===0){if(SUh(I,r,r+1));this.addingSourceDimension||D.push(Fh(r+1,r)),h=Oe({valid:h.valid,rank:r+1,names:[...h.names,""],ids:[...h.ids,fs()],timestamps:[...h.timestamps,Date.now()],scales:Float64Array.from([...h.scales,E]),units:[...h.units,x],boundingBoxes:D,coordinateArrays:[...h.coordinateArrays,void 0]}),p=Oe({valid:s.valid,rank:r+1,names:[...s.names,S],ids:[...s.ids,fs()],timestamps:[...s.timestamps,Date.now()],scales:Float64Array.from([...s.scales,E]),units:[...s.units,x],coordinateArrays:[...s.coordinateArrays,void 0]}),m=(0,De.Aw)(new Float64Array((r+2)**2),r+1,m,r)}m=Jh(Float64Array,m,h.rank,a,a),h=Kl(h,a),p=Kl(p,a);const g=p.ids.map((S,w)=>{const b=a[w];if(b===r)return S;const x=l[w],E=u[b];return x===E||this.dimensionRefCount(E)===1&&this.dimensionRefCount(x)===(u.includes(x)?1:0)?S:fs()}),v=p.timestamps.map((S,w)=>{const b=a[w];return b===r||l[w]===u[b]?S:Date.now()});p={...p,names:l,ids:g,timestamps:v};const y={rank:p.rank,sourceRank:d,outputSpace:p,inputSpace:h,transform:m};return this.transform.value=y,!0}updateModelTransform(){const e=this.coefficientElements,{rank:t}=this.transform.value,n=new Float64Array((t+1)**2);n[n.length-1]=1;for(let s=0;s{I.classList.add("neuroglancer-coordinate-space-transform-input"),E>=n&&I.classList.add(Fy)};{const I=document.createElement("div");I.classList.add("neuroglancer-coordinate-space-transform-input-name"),D(I),I.style.gridRowStart="sourceNames",I.style.gridColumnStart=`sourceDim ${E+1}`,y.appendChild(I),r.push(I)}{const{cellElement:I,inputElement:L,suggestionElement:N}=Gy();I.classList.add("neuroglancer-coordinate-space-transform-input-scale-container"),D(I),I.style.gridRowStart="sourceScales",I.style.gridColumnStart=`sourceDim ${E+1}`,S.appendChild(I),o.push(L),h.push(N);const k=E;N.addEventListener("click",()=>{const O=qh(this.transform,k);O!==void 0&&(this.transform.inputSpace.value=Jy(this.transform.inputSpace.value,k,O.scale,O.unit))})}{const I=document.createElement("div");D(I),I.classList.add("neuroglancer-coordinate-space-transform-input-bounds"),I.style.gridRowStart="sourceLower",I.style.gridColumnStart=`sourceDim ${E+1}`,w.appendChild(I);const L=document.createElement("div");D(L),L.classList.add("neuroglancer-coordinate-space-transform-input-bounds"),L.style.gridRowStart="sourceUpper",L.style.gridColumnStart=`sourceDim ${E+1}`,b.appendChild(L),s.push({lower:I,upper:L})}}for(let E=0;E{const{value:k}=this.transform,O=Kh(k,N);O!==void 0&&(this.transform.outputSpace.value=Jy(k.outputSpace,N,O.scale,O.unit))}),u.push(I),x.appendChild(D),d.push(L)}{const D=document.createElement("div");D.classList.add("neuroglancer-coordinate-space-transform-output-name-container"),D.style.gridRowStart=`outputDim ${E+1}`,D.style.gridColumnStart="outputNames";const I=Wy();I.title="Rebind to a different dimension",E>=n?I.title+=", or delete to remove singleton dimension":this.transform.mutableSourceRank&&(I.title+=", or delete to remove source dimension"),I.title+=". Names ending in ' or ^ indicate dimensions local to the layer; names ending in ^ indicate channel dimensions (image layers only).",c.push(I),v.appendChild(D),D.appendChild(I);const L=document.createElement("div");L.classList.add("neuroglancer-coordinate-space-transform-output-bounds"),D.appendChild(L);const N=document.createElement("div");N.classList.add("neuroglancer-coordinate-space-transform-output-bounds"),D.appendChild(N),p.push({lower:L,upper:N}),D.addEventListener("mousedown",k=>{k.target!==I&&(I.focus(),k.preventDefault())})}}c.push(this.addOutputDimensionInput),this.addOutputDimensionInput.value="",v.appendChild(this.addOutputDimensionCell),this.curSourceRank=n,this.curRank=t}updateViewInputScales(){this.ensureViewRankUpdated(),this.inputScaleModified.length=0;const{inputSpace:e,rank:t,sourceRank:n}=this.transform.value,{inputBoundsElements:s,inputNameElements:r,inputScaleElements:o,inputScaleSuggestionElements:a}=this,{names:l,scales:c,units:d,bounds:{lowerBounds:u,upperBounds:h,voxelCenterAtIntegerCoordinates:p}}=e;for(let m=0;mp?(i.style.left="",i.style.right=`${u-d.right}px`,c&&(i.style.maxWidth=h-o+"px")):(i.style.right="",i.style.left=`${d.left}px`,c&&(i.style.maxWidth=p-a+"px"))}if(n){const u=i.ownerDocument.documentElement.clientHeight,h=d.top-s,p=u-d.bottom-r;i.style.left=`${d.left}px`,i.style.width=`${d.width}px`,h>p*3?(i.style.top="",i.style.bottom=`${u-d.top}px`,l&&(i.style.maxHeight=h+"px")):(i.style.top=`${d.bottom}px`,i.style.bottom="",l&&(i.style.maxHeight=p+"px"))}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function VR(i){const e=i[Symbol.iterator](),{value:t,done:n}=e.next();if(n)return"";let s=t.length;for(;s>0;){const{value:r,done:o}=e.next();if(o)break;let a=0;for(;a0;){const e=i.match(/[:/_]+/);if(e===null){yield i;return}const t=e.index+e[0].length;yield i.substring(0,t),i=i.substring(t)}}function UR(i){const e=document.createElement("div");e.className="neuroglancer-multiline-autocomplete-completion-with-description",e.textContent=i.value;const t=document.createElement("div");return t.className="neuroglancer-multiline-autocomplete-completion-description",t.textContent=i.description||"",e.appendChild(t),e}const $R=Ae.fromObject({arrowdown:{action:"cycle-next-active-completion"},arrowup:{action:"cycle-prev-active-completion"},home:{action:"home"},end:{action:"end"},tab:{action:"choose-active-completion-or-prefix",preventDefault:!1},enter:{action:"commit"},escape:{action:"cancel",preventDefault:!1,stopPropagation:!1}}),GR=200;class zR extends T.O8{constructor(e){super(),this.element=document.createElement("div"),this.inputElement=document.createElement("span"),this.hintElement=document.createElement("span"),this.completionsVirtualList=void 0,this.onCommit=new j.HN,this.onInput=new j.HN,this.prevInputValue="",this.completionsVisible=!1,this.activeCompletionPromise=null,this.activeCompletionCancellationToken=void 0,this.hasFocus=!1,this.completionResult=null,this.dropdownContentsStale=!0,this.hasResultForDropdown=!1,this.commonPrefix="",this.completionDisabled=-1,this.activeIndex=-1,this.dropdownStyleStale=!0,this.resizeHandler=()=>{this.completionsVisible&&this.updateDropdownStyle()},this.resizeObserver=new ResizeObserver(this.resizeHandler),this.debouncedUpdateHintState=this.registerCancellable((0,Fe.A)(()=>this.updateHintState(),0)),this.completer=e.completer;const{delay:t=GR}=e,n=this.scheduleUpdateCompletions=(0,Fe.A)(()=>{const l=this.activeCompletionCancellationToken=new Je.Qi,c=this.activeCompletionPromise=this.completer(this.value,l);c!==null&&c.then(d=>{this.activeCompletionPromise===c&&(this.setCompletions(d),this.activeCompletionPromise=null)})},t);this.registerDisposer(()=>{n.cancel()});const{element:s,inputElement:r,hintElement:o}=this;s.classList.add("neuroglancer-multiline-autocomplete"),this.registerEventListener(window,"resize",this.resizeHandler),this.resizeObserver.observe(s),this.registerDisposer(()=>this.resizeObserver.unobserve(r)),r.contentEditable="true",r.spellcheck=!1,s.appendChild(document.createTextNode("\u200B")),s.appendChild(r),s.appendChild(o),r.classList.add("neuroglancer-multiline-autocomplete-input"),o.classList.add("neuroglancer-multiline-autocomplete-hint"),r.addEventListener("input",()=>{this.completionDisabled=-1,this.setValueAndSelection(this.value,this.getSelectionRange()),this.debouncedUpdateHintState()}),r.addEventListener("copy",l=>{const{clipboardData:c}=l;if(c!==null){const d=window.getSelection();d!==null&&!d.isCollapsed&&d.containsNode(r,!0)&&c.setData("text/plain",d.toString())}l.preventDefault(),l.stopPropagation()}),this.registerEventListener(document,"selectionchange",()=>{const l=this.getSelectionRange(),{completionDisabled:c}=this;l!==void 0&&l.begin===c&&l.end===c||(this.completionDisabled=-1,this.debouncedUpdateHintState())}),this.setValueAndSelection(""),this.updateHintState(),s.addEventListener("pointerdown",l=>{const{target:c}=l;if(c instanceof Node){if(r.contains(c))return;const{completionsVirtualList:d}=this;if(d?.element.contains(c))return}r===document.activeElement&&(this.moveCaretToEndOfInput(),l.stopPropagation(),l.preventDefault())}),s.addEventListener("click",()=>{r.focus()}),this.registerEventListener(this.inputElement,"focus",()=>{if(!this.hasFocus){this.hasFocus=!0,this.dropdownStyleStale=!0,this.updateDropdown();const l=document.createRange(),{childNodes:c}=r;l.setStart(r,0),c.length===0?l.setEnd(r,0):l.setEndAfter(c[c.length-1]);const d=window.getSelection();d!==null&&(d.removeAllRanges(),d.addRange(l)),this.debouncedUpdateHintState()}}),this.registerEventListener(this.inputElement,"blur",()=>{if(this.hasFocus){if(BR)return;this.hasFocus=!1,this.updateDropdown()}this.debouncedUpdateHintState();const l=window.getSelection();l!==null&&l.containsNode(this.inputElement,!0)&&l.removeAllRanges(),this.onCommit.dispatch(this.value,!1)}),this.registerEventListener(window,"resize",()=>{this.dropdownStyleStale=!0}),this.registerEventListener(window,"scroll",()=>{this.dropdownStyleStale=!0});const a=this.registerDisposer(new yn(r,$R));a.allShortcutsAreGlobal=!0,Z(r,"cycle-next-active-completion",()=>{this.cycleActiveCompletion(1)}),Z(r,"cycle-prev-active-completion",()=>{this.cycleActiveCompletion(-1)}),Z(r,"home",()=>{this.moveCaretToBeginningOfInput()}),Z(r,"end",()=>{this.moveCaretToEndOfInput()}),Z(r,"choose-active-completion-or-prefix",l=>{this.selectActiveCompletion(!0)&&l.preventDefault()}),Z(r,"commit",l=>{if(this.selectActiveCompletion(!1))l.stopPropagation();else{const c=!this.completionsVisible;this.disableCompletion(),this.hideCompletions(),this.onCommit.dispatch(this.value,c)}}),Z(r,"cancel",l=>{l.stopPropagation(),this.cancel()&&(l.detail.preventDefault(),l.detail.stopPropagation())})}disableCompletion(){const e=this.getSelectionRange();this.completionDisabled=e!==void 0&&e.end===e.begin?e.end:-1}get placeholder(){return this.inputElement.dataset.placeholder||""}set placeholder(e){this.inputElement.dataset.placeholder=e}getSelectionRange(){const e=window.getSelection();if(e===null||e.rangeCount===0)return;const t=e.getRangeAt(0),{inputElement:n}=this,s=document.createRange();s.setStart(n,0),s.setEnd(t.startContainer,t.startOffset);const r=s.toString().length,o=e.toString().length;return{begin:r,end:r+o}}setValueAndSelection(e,t=void 0){const n=this.completionDisabled!==-1;this.onInput.dispatch(e);const{inputElement:s}=this;Me(s);let r=0;const o=t!==void 0?document.createRange():void 0;let a=!0;for(const l of jy(e)){a||s.appendChild(document.createElement("wbr")),a=!1;const c=r+l.length,d=document.createTextNode(l);if(s.appendChild(d),o!==void 0){const{begin:u,end:h}=t;u>=r&&u<=c&&o.setStart(d,u-r),h>=r&&h<=c&&o.setEnd(d,h-r)}r=c}if(o!==void 0){a&&(o.setStart(s,0),o.setEnd(s,0));const l=window.getSelection();l!==null&&(l.removeAllRanges(),l.addRange(o))}this.completionDisabled=n&&t!==void 0&&t.end===t.begin?t.end:-1}shouldAttemptCompletion(){const{inputElement:e}=this;if(document.activeElement!==e)return!1;const t=this.getSelectionRange();return t!==void 0&&t.end===t.begin&&t.end!==this.completionDisabled&&t.end===this.value.length}hideCompletions(){this.cancelActiveCompletion(),this.clearCompletions(),this.hintElement.textContent=""}updateHintState(){if(this.debouncedUpdateHintState.cancel(),!this.shouldAttemptCompletion()){this.hideCompletions();return}const{value:e}=this;e!==this.prevInputValue&&(this.hideCompletions(),this.prevInputValue=e,this.scheduleUpdateCompletions())}handleDropdownClick(e){const{completionsVirtualList:t}=this;if(t===void 0)return;const n=t.element;for(let s=e.target;s instanceof HTMLElement&&s!==n;s=s.parentElement){const r=s.dataset.completionIndex;if(r!==void 0){this.selectCompletion(Number(r));break}}}cycleActiveCompletion(e){if(this.completionResult===null)return;let{activeIndex:t}=this;const n=this.completionResult.completions.length;t===-1?e>0?t=0:t=n-1:t=(t+e+n)%n,this.setActiveIndex(t)}shouldShowDropdown(){const{completionResult:e}=this;return e===null||!this.hasFocus?!1:this.hasResultForDropdown}updateDropdownStyle(){const{completionsVirtualList:e,element:t}=this;e!==void 0&&_R(e.element,t,{horizontal:!1}),this.dropdownStyleStale=!1}updateDropdown(){let{completionsVirtualList:e}=this;if(this.shouldShowDropdown()){if(this.dropdownContentsStale){e!==void 0&&e.dispose();const n=this.completionResult,{makeElement:s=FR}=n;e=this.completionsVirtualList=new Wr({source:{length:n.completions.length,render:r=>{const o=n.completions[r],a=s.call(n,o);return a.classList.add("neuroglancer-multiline-autocomplete-completion"),a.dataset.completionIndex=`${r}`,this.activeIndex===r&&a.classList.add(lu),a}},selectedIndex:this.activeIndex===-1?void 0:this.activeIndex}),e.element.classList.add("neuroglancer-multiline-autocomplete-dropdown"),e.element.addEventListener("mousedown",r=>{this.inputElement.focus(),r.preventDefault()}),e.element.addEventListener("mouseup",this.handleDropdownClick.bind(this)),this.element.appendChild(e.element),this.dropdownContentsStale=!1}this.dropdownStyleStale&&this.updateDropdownStyle(),this.completionsVisible||(this.completionsVisible=!0);const{activeIndex:t}=this;t!==-1&&this.completionsVirtualList.scrollItemIntoView(t)}else this.completionsVisible&&(e!==void 0&&(e.dispose(),this.completionsVirtualList=void 0,this.dropdownContentsStale=!0),this.completionsVisible=!1)}setCompletions(e){this.clearCompletions();const{completions:t}=e;if(t.length===0)return;const n=this.prevInputValue;if(n!==void 0){if(this.completionResult=e,t.length===1){const s=t[0];e.showSingleResult?this.hasResultForDropdown=!0:s.value.startsWith(n)?this.hasResultForDropdown=!1:this.hasResultForDropdown=!0,e.selectSingleResult?this.setActiveIndex(0):this.setHintValue(this.getCompletedValueByIndex(0))}else{this.hasResultForDropdown=!0;const s=VR(function*(){for(const o of e.completions)yield o.value}()),r=this.getCompletedValue(s);r.startsWith(n)&&(this.commonPrefix=r,this.setHintValue(r))}this.updateDropdown()}}setHintValue(e){const t=this.prevInputValue;if(t===void 0)return;(e===t||!e.startsWith(t))&&(e=""),e=e.substring(t.length);const{hintElement:n}=this;Me(n);let s=!0;for(const r of jy(e)){s||n.appendChild(document.createElement("wbr")),s=!1;const o=document.createTextNode(r);n.appendChild(o)}}setActiveIndex(e){if(!this.dropdownContentsStale){const{activeIndex:t}=this,{completionsVirtualList:n}=this;if(n!==void 0){if(t!==-1){const s=n.getItemElement(t);s!==void 0&&s.classList.remove(lu)}if(e!==-1){const s=n.getItemElement(e);s!==void 0&&s.classList.add(lu),n.scrollItemIntoView(e)}}}e!==-1&&this.setHintValue(this.getCompletedValueByIndex(e)),this.activeIndex=e}getCompletedValueByIndex(e){return this.getCompletedValue(this.completionResult.completions[e].value)}getCompletedValue(e){const t=this.completionResult,n=this.prevInputValue;return n===void 0?"":n.substring(0,t.offset)+e}moveCaretToBeginningOfInput(){const e=document.createRange(),{inputElement:t}=this;e.setStart(t,0),e.setEnd(t,0);const n=window.getSelection();n!==null&&(n.removeAllRanges(),n.addRange(e),this.debouncedUpdateHintState())}moveCaretToEndOfInput(){const e=document.createRange(),{inputElement:t}=this,{childNodes:n}=t,s=n[n.length-1];s===void 0?(e.setStart(t,0),e.setEnd(t,0)):(e.setStartAfter(s),e.setEndAfter(s));const r=window.getSelection();r!==null&&(r.removeAllRanges(),r.addRange(e),this.debouncedUpdateHintState())}selectActiveCompletion(e){let{activeIndex:t}=this;if(t===-1){if(!e)return!1;const{completionResult:s}=this;if(s!==null&&s.completions.length===1)t=0;else{const{commonPrefix:r}=this;return r.length>this.value.length?(this.value=r,this.moveCaretToEndOfInput(),!0):!1}}const n=this.getCompletedValueByIndex(t);return this.value===n?!1:(this.value=n,this.moveCaretToEndOfInput(),!0)}selectCompletion(e){this.value=this.getCompletedValueByIndex(e),this.moveCaretToEndOfInput()}cancel(){return!1}cancelActiveCompletion(){this.prevInputValue=void 0;const e=this.activeCompletionCancellationToken;e!==void 0&&e.cancel(),this.activeCompletionCancellationToken=void 0,this.activeCompletionPromise=null}clearCompletions(){if(this.completionResult!==null){this.activeIndex=-1,this.completionResult=null,this.dropdownContentsStale=!0,this.dropdownStyleStale=!0,this.commonPrefix="";const{completionsVirtualList:e}=this;e!==void 0&&(e.dispose(),this.completionsVirtualList=void 0),this.updateDropdown()}}get value(){return this.inputElement.textContent||""}set value(e){e!==this.value&&(this.completionDisabled=-1,this.setValueAndSelection(e),this.debouncedUpdateHintState())}disposed(){const{completionsVirtualList:e}=this;e!==void 0&&e.dispose(),at(this.element),this.cancelActiveCompletion(),super.disposed()}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class WR extends zR{constructor(e){const{manager:t}=e.source.layer,n=(r,o)=>t.dataSourceProviderRegistry.completeUrl({url:r,chunkManager:t.chunkManager,cancellationToken:o}).then(a=>({completions:a.completions,makeElement:UR,offset:a.offset,showSingleResult:!0}));super({completer:n,delay:0}),this.placeholder="Data source URL",this.dataSourceView=e,this.element.classList.add("neuroglancer-layer-data-source-url-input"),this.dirty=new _.B0(!1);const s=r=>{r!==this.dataSourceView.source.spec.url&&(this.dirty.value=!0)};s(""),this.onInput.add(s)}cancel(){return this.value=this.dataSourceView.source.spec.url,this.dirty.value=!1,this.inputElement.blur(),!0}}class cu extends T.O8{constructor(e){super(),this.model=e,this.element=document.createElement("ul"),this.generation=-1,this.element.classList.add("neuroglancer-layer-data-sources-source-messages");const t=this.registerCancellable((0,Qe.t)(()=>this.updateView()));this.registerDisposer(e.changed.add(t)),this.registerDisposer(()=>at(this.element)),this.updateView()}updateView(){const{model:e}=this,t=e.changed.count;if(t===this.generation)return;this.generation=t;const{element:n}=this;Me(n);const s=new Set;for(const r of e){const o=`${r.severity} ${r.message}`;if(s.has(o))continue;s.add(o);const a=document.createElement("li");n.appendChild(a),a.classList.add("neuroglancer-message"),a.classList.add(`neuroglancer-message-${Tn[r.severity]}`),a.textContent=r.message}}}class HR extends T.O8{constructor(e,t){super(),this.loadedSubsource=t,this.element=document.createElement("div");const{element:n}=this;n.classList.add("neuroglancer-layer-data-source-subsource");const s=document.createElement("label"),r=document.createElement("span"),o=()=>{s.dataset.isActive=(t.activated!==void 0||!t.enabled).toString()};o(),this.registerDisposer(t.isActiveChanged.add(o)),this.registerDisposer(e.enabledSubsourcesChanged.add(o));const a=this.registerDisposer(new pn({get value(){return t.enabled},set value(m){t.enabled=m,e.enableDefaultSubsources=!1,e.enabledSubsourcesChanged.dispatch()},changed:e.enabledSubsourcesChanged}));s.classList.add("neuroglancer-layer-data-sources-info-line"),s.appendChild(a.element);const l=document.createElement("span");l.classList.add("neuroglancer-layer-data-sources-source-id");const{id:c}=t.subsourceEntry;c!=="default"&&(l.textContent=c),s.appendChild(l),r.classList.add("neuroglancer-layer-data-sources-source-type");const d=this.registerDisposer(new cu(this.loadedSubsource.messages));n.appendChild(s),s.appendChild(r),n.appendChild(d.element);let u="";const{subsource:h}=t.subsourceEntry,{volume:p}=h;if(p instanceof ln)u=`${R[p.dataType].toLowerCase()} volume`;else if(h.mesh instanceof Qi)u="meshes (single-res.)";else if(h.mesh instanceof Ra)u="meshes (multi-res.)";else if(h.mesh instanceof Oa)u="skeletons";else if(h.segmentPropertyMap!==void 0)u="segment property map";else if(h.local!==void 0)switch(h.local){case As.annotations:u="Local annotations";break;case As.equivalences:u="local segmentation graph";break}else h.staticAnnotations!==void 0?u="default annotations":h.annotation!==void 0?u="annotations":h.singleMesh!==void 0?u="single mesh":h.segmentationGraph!==void 0&&(u="segmentation graph");r.textContent=u}}class JR extends T.O8{constructor(e){super(),this.source=e,this.element=document.createElement("div");const{element:t}=this,n=document.createElement("label");n.classList.add("neuroglancer-layer-data-sources-source-default"),n.appendChild(this.registerDisposer(new pn({changed:e.enabledSubsourcesChanged,get value(){return e.enableDefaultSubsources},set value(r){if(e.enableDefaultSubsources!==r){if(e.enableDefaultSubsources=r,r)for(const o of e.subsources)o.enabled=o.subsourceEntry.default;e.enabledSubsourcesChanged.dispatch()}}})).element),n.appendChild(document.createTextNode("Enable default subsource set")),n.title="Enable the default set of subsources for this data source.",t.appendChild(n);for(const r of e.subsources)t.appendChild(this.registerDisposer(new HR(e,r)).element);const{transform:s}=e;if(s.mutableSourceRank||s.value.sourceRank!==0){const r=this.registerDisposer(new OR(e.transform,e.layer.localCoordinateSpaceCombiner,e.layer.manager.root.coordinateSpaceCombiner));this.element.appendChild(r.element)}this.registerDisposer(()=>at(this.element))}}class jR extends T.O8{constructor(e,t){super(),this.tab=e,this.source=t,this.element=document.createElement("div"),this.seenGeneration=0,this.generation=-1;const n=this.urlInput=this.registerDisposer(new WR(this)),s=(o,a)=>{const{source:l}=this,c=l.spec,d=this.source.layer;if(o=d.manager.dataSourceProviderRegistry.normalizeUrl({url:o}),o!==n.value&&(n.disableCompletion(),n.setValueAndSelection(o,{begin:o.length,end:o.length})),n.dirty.value=!1,o&&o===c.url){a&&e.detectedLayerConstructor!==void 0&&Yy(l.layer);return}if(d instanceof jn)try{const u=d.manager.dataSourceProviderRegistry.suggestLayerName(o);Jg(d.managedLayer,u)}catch{}l.spec={...c,url:o}};n.onCommit.add(s);const{element:r}=this;r.classList.add("neuroglancer-layer-data-source"),r.appendChild(n.element),r.appendChild(this.registerDisposer(new cu(t.messages)).element),this.updateView()}updateView(){const e=this.source.changed.count;if(e===this.generation)return;this.generation=e,this.urlInput.value=this.source.spec.url,this.urlInput.dirty.value=!1;const{loadState:t}=this.source;let{loadedView:n}=this;if(n!==void 0){if(n.source===t)return;n.dispose(),n=this.loadedView=void 0}t instanceof Yc&&(n=this.loadedView=new JR(t),this.element.appendChild(n.element))}disposed(){const{loadedView:e}=this;e!==void 0&&e.dispose(),at(this.element),super.disposed()}}function Yy(i){if(i instanceof jn){const e=i.detectedLayerConstructor;if(e!==void 0)return Zc(i.managedLayer,e),!0}return!1}class YR extends Gt{constructor(e){super(),this.layer=e,this.generation=-1,this.sourceViews=new Map,this.addDataSourceIcon=qd({title:"Add additional data source"}),this.layerTypeDetection=document.createElement("div"),this.layerTypeElement=document.createElement("span"),this.dataSourcesContainer=document.createElement("div"),this.detectedLayerConstructor=void 0;const{element:t,dataSourcesContainer:n}=this;t.classList.add("neuroglancer-layer-data-sources-tab"),n.classList.add("neuroglancer-layer-data-sources-container");const{addDataSourceIcon:s}=this;if(s.style.alignSelf="start",s.addEventListener("click",()=>{const o=this.layer.addDataSource(void 0);this.updateView();const a=this.sourceViews.get(o);a!==void 0&&a.urlInput.inputElement.focus()}),t.appendChild(this.dataSourcesContainer),e instanceof jn){const{layerTypeDetection:o,layerTypeElement:a}=this;o.style.display="none",a.classList.add("neuroglancer-layer-data-sources-tab-type-detection-type"),o.appendChild(document.createTextNode("Create as ")),o.appendChild(a),o.appendChild(document.createTextNode(" layer")),t.appendChild(o),o.classList.add("neuroglancer-layer-data-sources-tab-type-detection"),o.addEventListener("click",()=>{Yy(e)})}const r=this.reRender=(0,Qe.t)(()=>this.updateView());this.registerDisposer(e.dataSourcesChanged.add(r)),this.registerDisposer(this.visibility.changed.add(r)),this.updateView()}updateLayerTypeDetection(){const e=(()=>{const n=this.layer;if(!(n instanceof jn))return;const s=n.detectedLayerConstructor;if(s!==void 0){for(const r of this.sourceViews.values())if(r.urlInput.dirty.value)return;return s}})();if(e===this.detectedLayerConstructor)return;const{layerTypeDetection:t}=this;if(this.detectedLayerConstructor=e,e!==void 0){const{layerTypeElement:n}=this;n.textContent=e.type,t.title=`Click here or press enter in the data source URL input box to create as ${e.type} layer`,t.style.display=""}else t.style.display="none"}disposed(){const{sourceViews:e}=this;for(const t of e.values())t.dispose();e.clear(),super.disposed()}updateView(){if(!this.visible)return;const e=this.layer.dataSourcesChanged.count;if(e!==this.generation){this.generation=e;const t=Date.now(),{sourceViews:n}=this,{layer:s}=this;function*r(){let o=!0;const{dataSources:a}=s;for(const l of a){let c=n.get(l);c===void 0&&(c=new jR(this,l),c.registerDisposer(c.urlInput.dirty.changed.add(this.reRender)),n.set(l,c)),c.seenGeneration=t,c.updateView();const d=l.spec.url;a.length===1&&d===""&&setTimeout(()=>{c.urlInput.inputElement.focus()},0),o=l.spec.url.length===0,yield c.element}o||(yield this.addDataSourceIcon)}nn(this.dataSourcesContainer,r.call(this));for(const[o,a]of n)a.seenGeneration!==t&&(a.dispose(),n.delete(o))}this.updateLayerTypeDetection()}}Ag.push({id:"source",label:"Source",order:-100,getter:i=>new YR(i)});/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class QR extends T.O8{constructor(e){super(),this.ref=e,this.element=document.createElement("label"),this.selectElement=document.createElement("select"),this.registerDisposer(e);const{element:t,selectElement:n}=this;t.appendChild(n),this.updateView(),this.registerEventListener(n,"change",()=>this.updateModel()),this.registerDisposer(this.ref.changed.add((0,Fe.A)(()=>this.updateView(),0)))}updateModel(){this.ref.layerName=this.selectElement.value||void 0}updateView(){const{selectElement:e,ref:t}=this,{filter:n}=t;Me(e);const s=document.createElement("option");e.appendChild(s);for(const r of this.ref.layerManager.managedLayers)if(n(r)){const o=document.createElement("option"),{name:a}=r;o.textContent=a,o.value=a,e.appendChild(o)}e.value=t.layerName||""}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const KR="points",du="annotations",Qy="annotationProperties",Ky="annotationRelationships",qy="crossSectionAnnotationSpacing",Xy="projectionAnnotationSpacing",Zy="shader",eS="shaderControls";function qR(i,e){e!==void 0&&(0,f.$v)(e,(t,n)=>{i.add({type:Re.POINT,id:""+n,point:(0,f.f4)(t),properties:[]})})}function XR(i){const e=i.layer;return e===null||e instanceof Ct}function ZR(i){if(i===void 0)return null;const e=i.layer;return e===null||!(e instanceof Ct)?null:e.displayState}const tS="linkedSegmentationLayer",nS="filterBySegmentation",iS="ignoreNullSegmentFilter",sS="swapVisbleSegmentsOnMove";class ek extends T.O8{constructor(e,t,n){super(),this.layerManager=e,this.annotationStates=t,this.annotationDisplayState=n,this.changed=new j.IY,this.curGeneration=-1,this.wasLoading=void 0,this.map=new Map,this.registerDisposer(t.changed.add(()=>this.update())),this.registerDisposer(t.isLoadingChanged.add(()=>this.update())),this.update()}update(){const e=this.annotationStates.changed.count,t=this.annotationStates.isLoading;if(this.curGeneration===e&&t===this.wasLoading)return;this.wasLoading=t,this.curGeneration=e;const{map:n}=this;let s=!1;for(const r of this.annotationStates.relationships){let o=n.get(r);o===void 0&&(o=this.addRelationship(r),s=!0),o.seenGeneration=e}if(!t){const{relationshipStates:r}=this.annotationDisplayState;for(const[o,a]of n)a.seenGeneration!==e&&(n.delete(o),r.delete(o),s=!0)}s&&this.changed.dispatch()}addRelationship(e){const t=this.annotationDisplayState.relationshipStates.get(e),n=new zT(this.layerManager.addRef(),XR);n.registerDisposer(n.changed.add(()=>{t.segmentationState.value=n.layerName===void 0?void 0:ZR(n.layer)}));const{showMatches:s}=t,r={layerRef:n,showMatches:s,seenGeneration:-1};return n.changed.add(this.changed.dispatch),s.changed.add(this.changed.dispatch),this.map.set(e,r),r}get(e){return this.update(),this.map.get(e)}unbind(e){e.layerRef.changed.remove(this.changed.dispatch),e.showMatches.changed.remove(this.changed.dispatch)}reset(){for(const e of this.map.values())e.showMatches.reset()}toJSON(){const{map:e}=this;if(e.size===0)return{};let t;const n=[];for(const[s,r]of e){r.showMatches.value&&n.push(s);const{layerName:o}=r.layerRef;o!==void 0&&((t=t||{})[s]=o)}return n.sort(),{[tS]:t,[nS]:n.length===0?void 0:n}}restoreState(e){const{isLoading:t}=this.annotationStates;(0,f.MM)(e,tS,n=>{typeof n=="string"&&(n={segments:n}),(0,f.Rf)(n);for(const s of Object.keys(n)){const r=(0,f.zr)(n[s]);let o=this.map.get(s);if(o===void 0){if(!t)continue;o=this.addRelationship(s)}o.layerRef.layerName=r}for(const[s,r]of this.map)Object.prototype.hasOwnProperty.call(n,s)||(r.layerRef.layerName=void 0)}),(0,f.MM)(e,nS,n=>{typeof n=="boolean"&&(n=n===!0?["segments"]:[]);for(const s of(0,f.si)(n)){let r=this.map.get(s);if(r===void 0){if(!t)continue;r=this.addRelationship(s)}r.showMatches.value=!0}})}disposed(){const{map:e}=this;for(const t of e.values())this.unbind(t);e.clear(),super.disposed()}}class tk extends T.O8{constructor(e,t){super(),this.relationship=e,this.state=t,this.element=document.createElement("label"),this.seenGeneration=-1;const{element:n}=this,s=this.registerDisposer(new pn(t.showMatches)),r=new QR(t.layerRef);n.appendChild(s.element),n.appendChild(document.createTextNode(e)),n.appendChild(r.element)}}class nk extends T.O8{constructor(e){super(),this.linkedSegmentationLayers=e,this.widgets=new Map,this.element=document.createElement("div"),this.element.style.display="contents";const t=this.registerCancellable((0,Qe.t)(()=>this.updateView()));this.registerDisposer(this.linkedSegmentationLayers.annotationStates.changed.add(t)),this.updateView()}updateView(){const{linkedSegmentationLayers:e}=this,{annotationStates:t}=e,n=t.changed.count,{widgets:s}=this;function*r(){for(const o of t.relationships){let a=s.get(o);a===void 0&&(a=new tk(o,e.get(o))),a.seenGeneration=n,yield a.element}}for(const[o,a]of s)a.seenGeneration!==n&&(a.dispose(),s.delete(o));nn(this.element,r.call(this))}disposed(){super.disposed();for(const e of this.widgets.values())e.dispose()}}function uu(i){const{localAnnotations:e}=i;if(e){const t=i.manager.root.selectionState.value?.layers.find(n=>n.layer===i);if(t&&t.state.annotationId)return e.get(t.state.annotationId)}}function hu(i,e){const t=i.getReference(e.id);i.update(t,e),i.commit(t)}const rS=class Jb extends gi{constructor(e,t){super(t,!0),this.propertyIdentifier=e}get tag(){const{localAnnotations:e}=this.layer;if(e){const t=e.properties.value.find(n=>n.identifier===this.propertyIdentifier);if(t&&us(t))return t.tag}return"unknown"}activate(e){const{localAnnotations:t}=this.layer;if(!t)return;const n=uu(this.layer);if(n){const{propertyIdentifier:s}=this,r=t.properties.value.findIndex(o=>o.identifier===s);r>-1&&(n.properties[r]=1-n.properties[r],hu(t,n))}e.cancel()}toJSON(){return`${Jb.TOOL_ID}_${this.propertyIdentifier}`}get description(){return`tag ${this.tag}`}};rS.TOOL_ID="tagTool";let Ws=rS;class ik extends Gt{constructor(e){super(),this.layer=e,this.tools=new Set;const{element:t}=this;t.classList.add("neuroglancer-tags-tab");const{localAnnotations:n}=e;if(!n)return;const{properties:s}=n,r=document.createElement("div");r.classList.add("neuroglancer-tags-container"),t.appendChild(r);let o=0,a=[];const l=new ai,c=v=>(l.clearMessages(),a.includes(v)?(l.addMessage({severity:Tn.error,message:`tag: "${v}" already exists`}),!1):!0),d=v=>{const{properties:y}=v;let S=-1;for(const w of y.value){const b=w.identifier.match(/tag([\d]+)/);S++,b&&b.length>1&&(S=parseInt(b[1]))}return`tag${S+1}`},u=v=>{const{value:y}=v;v.validity.valid&&c(y)&&n.addProperty({type:"uint8",tag:y,default:0,description:void 0,identifier:d(n)})},h={length:1,render:v=>{const y=document.createElement("div");y.classList.add("neuroglancer-tag-list-entry");const S=document.createElement("input");if(S.required=!0,y.append(S),v===h.length-1){y.classList.add("add");const w=Wn(this,e.toolBinder,{toolJson:`${Ws.TOOL_ID}__invalid`});y.prepend(w),S.placeholder="Tag name",o{S.focus()},0),S.addEventListener("keyup",x=>{x.key==="Enter"&&u(S)});const b=qd({title:"Add additional tag",onClick:()=>u(S)});y.append(b),o=h.length}else{const w=n.getTagProperties()[v],{tag:b}=w,x=Wn(this,e.toolBinder,{toolJson:`${Ws.TOOL_ID}_${w.identifier}`,title:`Tag selected annotation with ${b}`});y.prepend(x),S.value=b,S.addEventListener("change",()=>{const{value:D}=S;if(!c(D)||!confirm(`Rename tag ${b} to ${D}?`)){S.value=b;return}w.tag=D,s.changed.dispatch();const I=uu(this.layer);I&&hu(n,I)});const E=Mn({title:"Delete tag",onClick:D=>{D.stopPropagation(),D.preventDefault(),confirm(`Delete tag ${b}?`)&&n.removeProperty(w.identifier);const I=uu(this.layer);I&&hu(n,I)}});E.classList.add("neuroglancer-tag-list-entry-delete"),y.append(E)}return y},changed:new j.IY},p=this.registerDisposer(new Wr({source:h}));r.appendChild(p.element);const m=this.registerDisposer(new cu(l));r.appendChild(m.element),p.body.classList.add("neuroglancer-tag-list"),p.element.classList.add("neuroglancer-tag-list-outer");const g=()=>{let v=1,y=0,S=0;const w=n.getTagProperties().map(b=>b.tag);for(const b of w)a.includes(b)?v++:S++;for(const b of a)w.includes(b)||y++;h.length=w.length+1,a=w,(y>0||S>0)&&h.changed.dispatch([{retainCount:v,deleteCount:y,insertCount:S}])};this.registerDisposer(s.changed.add(g)),g()}}const sk=Zd(Rn),pu=class wh extends sk{constructor(e){super(e),this.localAnnotationProperties=new _.B0([]),this.localAnnotationsJson=void 0,this.pointAnnotationsJson=void 0,this.tagTools=[],this.linkedSegmentationLayers=this.registerDisposer(new ek(this.manager.rootLayers,this.annotationStates,this.annotationDisplayState)),this.syncTagTools=n=>{for(const s of this.tagTools)if(!n.includes(s)){Ix(wh,`${Ws.TOOL_ID}_${s}`);for(const[r,o]of this.toolBinder.bindings.entries())o instanceof Ws&&o.propertyIdentifier===s&&this.toolBinder.deleteTool(r)}this.tagTools=this.tagTools.filter(s=>n.includes(s));for(const s of n)this.tagTools.includes(s)||(this.tagTools.push(s),sn(wh,`${Ws.TOOL_ID}_${s}`,r=>new Ws(s,r)))},this.linkedSegmentationLayers.changed.add(this.specificationChanged.dispatch),this.annotationDisplayState.ignoreNullSegmentFilter.changed.add(this.specificationChanged.dispatch),this.annotationCrossSectionRenderScaleTarget.changed.add(this.specificationChanged.dispatch),this.annotationProjectionRenderScaleTarget.changed.add(this.specificationChanged.dispatch),this.registerDisposer(this.localAnnotationProperties.changed.add(()=>{const{localAnnotations:n}=this;if(n){const s=n.getTagProperties().map(r=>r.identifier);this.syncTagTools(s)}})),this.tabs.add("rendering",{label:"Rendering",order:-100,getter:()=>new ok(this)});const t=this.registerDisposer(new _.ww(()=>this.localAnnotations===void 0,this.dataSourcesChanged));this.tabs.add("tags",{label:"Tags",order:10,getter:()=>new ik(this),hidden:t}),this.tabs.default="annotations"}disposed(){const{localAnnotations:e}=this;e!==void 0&&e.dispose(),super.disposed()}restoreState(e){const t=(0,f.MM)(e,Qy,Dh);t&&this.syncTagTools(t.filter(us).map(n=>n.identifier)),super.restoreState(e),this.linkedSegmentationLayers.restoreState(e),this.localAnnotationsJson=e[du],t&&(this.localAnnotationProperties.value=t||[]),this.localAnnotationRelationships=(0,f.MM)(e,Ky,f.si,["segments"]),this.pointAnnotationsJson=e[KR],this.annotationCrossSectionRenderScaleTarget.restoreState(e[qy]),this.annotationProjectionRenderScaleTarget.restoreState(e[Xy]),this.annotationDisplayState.ignoreNullSegmentFilter.restoreState(e[iS]),this.annotationDisplayState.swapVisibleSegmentsOnMove.restoreState(e[sS]),this.annotationDisplayState.shader.restoreState(e[Zy]),this.annotationDisplayState.shaderControls.restoreState(e[eS])}getLegacyDataSourceSpecifications(e,t,n,s){if(Object.prototype.hasOwnProperty.call(t,"source"))return super.getLegacyDataSourceSpecifications(e,t,n,s);const r=(0,f.MM)(t,"voxelSize",a=>(0,f.Xu)(new Float64Array(3),a,l=>(0,f.Mo)(l)/1e9)),o=["m","m","m"];if(r!==void 0){const a=Oe({rank:3,units:o,scales:r,names:["x","y","z"]});n===void 0?n={outputSpace:a,sourceRank:3,transform:void 0,inputSpace:a}:n={...n,inputSpace:a}}return[{url:bg,transform:n,enableDefaultSubsources:!0,subsources:new Map}]}activateDataSubsources(e){let t=!1,n;for(const s of e){const{subsourceEntry:r}=s,{local:o}=r.subsource,a=c=>n!==void 0&&(0,f.JB)(c.value)!==(0,f.JB)(n.value)?(s.deactivate("Annotation properties are not compatible"),!1):(n=c,!0);if(o===As.annotations){if(t){s.deactivate("Only one local annotations source per layer is supported");continue}if(t=!0,!a(this.localAnnotationProperties))continue;s.activate(c=>{const d=this.localAnnotations=new Ih(s.loadedDataSource.transform,this.localAnnotationProperties,this.localAnnotationRelationships);try{d.restoreState(this.localAnnotationsJson)}catch{}c.registerDisposer(()=>{d.dispose(),this.localAnnotations=void 0}),c.registerDisposer(this.localAnnotations.changed.add(()=>{this.specificationChanged.dispatch()}));try{qR(this.localAnnotations,this.pointAnnotationsJson)}catch{}this.pointAnnotationsJson=void 0,this.localAnnotationsJson=void 0;const u=new jo({localPosition:this.localPosition,transform:c.registerDisposer(Xh(this.manager.root.coordinateSpace,this.localPosition.coordinateSpace,s.loadedDataSource.transform,void 0)),source:d.addRef(),displayState:this.annotationDisplayState,dataSource:s.loadedDataSource.layerDataSource,subsourceIndex:s.subsourceIndex,subsourceId:r.id,role:li.ANNOTATION});this.addAnnotationLayerState(u,s)});continue}const{annotation:l}=r.subsource;if(l!==void 0){if(!a(l.properties))continue;s.activate(()=>{const c=new jo({localPosition:this.localPosition,transform:s.getRenderLayerTransform(),source:l,displayState:this.annotationDisplayState,dataSource:s.loadedDataSource.layerDataSource,subsourceIndex:s.subsourceIndex,subsourceId:r.id,role:li.ANNOTATION});this.addAnnotationLayerState(c,s)});continue}s.deactivate("Not compatible with annotation layer")}n&&(0,f.JB)(this.annotationDisplayState.annotationProperties.value)!==(0,f.JB)(n?.value)&&(this.registerDisposer(n.changed.add(()=>{this.annotationDisplayState.annotationProperties.value=[...n.value]})),this.annotationDisplayState.annotationProperties.value=[...n.value])}initializeAnnotationLayerViewTab(e){const t=e.registerDisposer((0,_.ol)(s=>s.some(r=>r.source instanceof Rr),this.annotationStates)),n=e.registerDisposer(new Wt(t,(s,r,o)=>{if(s){{const a=o.registerDisposer(new ga(this.annotationCrossSectionRenderScaleHistogram,this.annotationCrossSectionRenderScaleTarget));a.label.textContent="Spacing (cross section)",r.appendChild(a.element)}{const a=o.registerDisposer(new ga(this.annotationProjectionRenderScaleHistogram,this.annotationProjectionRenderScaleTarget));a.label.textContent="Spacing (projection)",r.appendChild(a.element)}}}));e.element.insertBefore(n.element,e.element.firstChild);{const s=e.registerDisposer(new pn(this.annotationDisplayState.ignoreNullSegmentFilter)),r=document.createElement("label");r.appendChild(document.createTextNode("Ignore null related segment filter")),r.title="Display all annotations if filtering by related segments is enabled but no segments are selected",r.appendChild(s.element),e.element.appendChild(r)}{const s=e.registerDisposer(new pn(this.annotationDisplayState.swapVisibleSegmentsOnMove)),r=document.createElement("label");r.appendChild(document.createTextNode("Swap visible segments when moving to annotation")),r.title="Swap visible segments when moving to annotation",r.appendChild(s.element),e.element.appendChild(r)}e.element.appendChild(e.registerDisposer(new nk(this.linkedSegmentationLayers)).element)}toJSON(){const e=super.toJSON();e[qy]=this.annotationCrossSectionRenderScaleTarget.toJSON(),e[Xy]=this.annotationProjectionRenderScaleTarget.toJSON(),this.localAnnotations!==void 0?e[du]=this.localAnnotations.toJSON():this.localAnnotationsJson!==void 0&&(e[du]=this.localAnnotationsJson),e[Qy]=tC(this.localAnnotationProperties.value);const{localAnnotationRelationships:t}=this;return e[Ky]=t.length===1&&t[0]==="segments"?void 0:t,e[iS]=this.annotationDisplayState.ignoreNullSegmentFilter.toJSON(),e[sS]=this.annotationDisplayState.swapVisibleSegmentsOnMove.toJSON(),e[Zy]=this.annotationDisplayState.shader.toJSON(),e[eS]=this.annotationDisplayState.shaderControls.toJSON(),Object.assign(e,this.linkedSegmentationLayers.toJSON()),e}};pu.type="annotation",pu.typeAbbreviation="ann";let Qr=pu;function oS(i){return new Ja({shaderError:i.annotationDisplayState.shaderError,fragmentMain:i.annotationDisplayState.shader,shaderControlState:i.annotationDisplayState.shaderControls})}class rk extends Jr{constructor(e){super(),this.layer=e,this.codeWidget=this.registerDisposer(oS(this.layer)),this.content.appendChild(this.codeWidget.element),this.codeWidget.textEditor.refresh()}}class ok extends Gt{constructor(e){super(),this.layer=e,this.codeWidget=this.registerDisposer(oS(this.layer));const{element:t}=this;t.classList.add("neuroglancer-annotation-rendering-tab"),t.appendChild(this.registerDisposer(new Wt(e.annotationDisplayState.annotationProperties,(r,o)=>{if(r===void 0||r.length===0)return;const a=document.createElement("div");o.appendChild(a),a.classList.add("neuroglancer-annotation-shader-property-list");for(const l of r){const c=document.createElement("div");c.classList.add("neuroglancer-annotation-shader-property");const d=document.createElement("span");d.classList.add("neuroglancer-annotation-shader-property-type"),d.textContent=l.type;const u=document.createElement("span");u.classList.add("neuroglancer-annotation-shader-property-identifier"),u.textContent=`prop_${l.identifier}`,c.appendChild(d),c.appendChild(u);const{description:h}=l;if(h!==void 0&&(c.title=h),us(l)){const p=document.createElement("span");p.classList.add("neuroglancer-annotation-tag-property-type"),p.textContent=`(${l.tag})`,c.appendChild(p)}a.appendChild(c)}})).element);const n=document.createElement("div");n.className="neuroglancer-segmentation-dropdown-skeleton-shader-header";const s=document.createElement("div");s.style.flex="1",s.textContent="Annotation shader:",n.appendChild(s),n.appendChild(Ha({title:"Show larger editor view",onClick:()=>{new rk(this.layer)}})),n.appendChild(Wa({title:"Documentation on annotation rendering",href:"https://github.com/google/neuroglancer/blob/master/src/annotation/rendering.md"})),t.appendChild(n),t.appendChild(this.codeWidget.element),t.appendChild(this.registerDisposer(new ja(e.annotationDisplayState.shaderControls,this.layer.manager.root.display,this.layer,{visibility:this.visibility})).element)}}$i(Qr),$i(Qr,"pointAnnotation"),da(i=>{if(i.local===As.annotations)return{layerConstructor:Qr,priority:100};if(i.annotation!==void 0)return{layerConstructor:Qr,priority:1}}),Ya(Qr,i=>({shaderControlState:i.annotationDisplayState.shaderControls}));/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var fu=(i=>(i[i.DEFAULT=0]="DEFAULT",i[i.ADDITIVE=1]="ADDITIVE",i))(fu||{});const ak=new Map([[0,i=>{i.blendFunc(i.SRC_ALPHA,i.ONE_MINUS_SRC_ALPHA)}],[1,i=>{i.blendFunc(i.SRC_ALPHA,i.ONE)}]]);function lk(i=0){return new Oi.F(fu,i)}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const aS=`#uicontrol invlerp normalized +void main() { + emitGrayscale(normalized()); +} +`;function ck(i=aS){return Co(i)}function lS(i,e){i.addFragmentCode(` +#define VOLUME_RENDERING false + +void emitRGBA(vec4 rgba) { + emit(vec4(rgba.rgb, rgba.a * uOpacity)); +} +void emitRGB(vec3 rgb) { + emit(vec4(rgb, uOpacity)); +} +void emitGrayscale(float value) { + emit(vec4(value, value, value, uOpacity)); +} +void emitTransparent() { + emit(vec4(0.0, 0.0, 0.0, 0.0)); +} +void emitIntensity(float value) { +} +`),i.addFragmentCode(Is),Ts(e,i),i.setFragmentMainFunction(ms(e.parseResult.code))}class dk extends Mv{constructor(e,t){const{opacity:n,blendMode:s,shaderControlState:r}=t;super(e,{...t,fallbackShaderParameters:new _.B0(Ho(Er(aS,{imageData:{dataType:e.dataType,channelRank:t.channelCoordinateSpace?.value?.rank??0}}))),encodeShaderParameters:o=>o.key,shaderParameters:r.builderState,dataHistogramSpecifications:r.histogramSpecifications}),this.shaderControlState=r,this.opacity=n,this.blendMode=s,this.registerDisposer(n.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(s.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(r.changed.add(this.redrawNeeded.dispatch))}defineShader(e,t){if(t.parseResult.errors.length!==0)throw new Error("Invalid UI control specification");e.addUniform("highp float","uOpacity"),lS(e,t)}initializeShader(e,t,n){const{gl:s}=this;s.uniform1f(t.uniform("uOpacity"),this.opacity.value),vi(s,t,this.shaderControlState,n.parseResult.controls)}setGLBlendMode(e,t){const n=this.blendMode.value;n===fu.ADDITIVE||t>0?(e.enable(e.BLEND),ak.get(n)(e)):e.disable(WebGL2RenderingContext.BLEND)}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function uk(i=1){return new _.DN(i,f.zo)}var cn=(i=>(i[i.OFF=0]="OFF",i[i.ON=1]="ON",i[i.MAX=2]="MAX",i[i.MIN=3]="MIN",i))(cn||{});function cS(i=0){return new Oi.F(cn,i)}function Xi(i){return i===2||i===3}function dS(i){return Xi(i.mode.value)}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const hk="volume_rendering/VolumeRenderingRenderLayer",pk="volume_rendering/VolumeRenderingRenderLayer/update",fk=!1,gk=C.w0.create();function mk(i,e,t){let n=0,s=0;for(let c=0;c<3;++c){const d=i[16+c],u=d*e[c],h=d*t[c];n+=Math.min(u,h),s+=Math.max(u,h)}const r=-i[19],o=Math.max(r,n),a=i[23],l=Math.min(a,s);return{near:r,far:a,adjustedNear:o,adjustedFar:l}}function uS(i,e,t,n,s,r){if(n.length===0)return;const{viewMatrix:o,projectionMat:a,displayDimensionRenderInfo:l}=i,{voxelPhysicalScales:c}=l,d=(0,C.xK)(c),u=(0,C.sJ)(a),p=(u/t)**3,m=C.w0.determinant((0,C._A)(gk,o)),g={spatialScales:new Map,activeIndex:-1},v=D=>{const I=n[D];return Math.abs(I.chunkLayout.detTransform*m)};let y=n.length-1,S=v(y);for(let D=y;D>=0;--D){const I=v(D),L=Math.cbrt(I*d/m),N=u/Math.cbrt(I);g.spatialScales.set(L,N),I-p>=0&&(S=I,y=D),g.activeIndex=y}if(fk){console.log(n);for(let D=0;D{x&&(s(E,y,w,b,I,g),x=!1),r(E,y,D)})}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const vk=64,hS=1,yk=10,gu=256,Sk=2**14,bk=!1,mu=Symbol("depthSamplerTextureUnit"),Ck=` +void emitRGBA(vec4 rgba) { + float correctedAlpha = clamp(rgba.a * uBrightnessFactor * uGain, 0.0, 1.0); + float weightedAlpha = correctedAlpha * computeOITWeight(correctedAlpha, depthAtRayPosition); + outputColor += vec4(rgba.rgb * weightedAlpha, weightedAlpha); + revealage *= 1.0 - correctedAlpha; +} +`,wk=C.pB.create(),xk=new Float32Array(24);function pS(){const i=Math.round(hS+mt*Ir);return[hS,i]}function fS(i){const e=pS(),t=[2**e[0],2**e[1]-1];return Pe(t,Math.round(i))}class Ek extends Gi{get gl(){return this.multiscaleSource.chunkManager.gl}get isTransparent(){return!0}get isVolumeRendering(){return!0}getDataHistogramCount(){return this.dataHistogramSpecifications.visibleHistograms}constructor(e){super(),this.gain=e.gain,this.multiscaleSource=e.multiscaleSource,this.transform=e.transform,this.channelCoordinateSpace=e.channelCoordinateSpace,this.shaderControlState=e.shaderControlState,this.localPosition=e.localPosition,this.depthSamplesTarget=e.depthSamplesTarget,this.chunkResolutionHistogram=e.chunkResolutionHistogram,this.mode=e.mode,this.modeOverride=cS(),this.dataHistogramSpecifications=this.shaderControlState.histogramSpecifications,this.histogramIndexBuffer=this.registerDisposer(ci(this.gl,WebGL2RenderingContext.ARRAY_BUFFER,()=>new Uint8Array(gu))),this.registerDisposer(this.chunkResolutionHistogram.visibility.add(this.visibility)),this.registerDisposer(this.dataHistogramSpecifications.producerVisibility.add(this.visibility));const t=this.registerDisposer((0,_.Uq)((o,a,l,c)=>({numChannelDimensions:o.rank,mode:l===cn.OFF?a:l,dataHistogramChannelSpecifications:c}),[this.channelCoordinateSpace,this.mode,this.modeOverride,this.dataHistogramSpecifications.channels]));this.shaderGetter=wo(this,this.gl,{memoizeKey:"VolumeRenderingRenderLayer",parameters:e.shaderControlState.builderState,getContextKey:({emitter:o,chunkFormat:a,wireFrame:l})=>`${xt(o)}:${a.shaderKey}:${l}`,shaderError:e.shaderError,extraParameters:t,defineShader:(o,{emitter:a,chunkFormat:l,wireFrame:c},d,u)=>{if(d.parseResult.errors.length!==0)throw new Error("Invalid UI control specification");xi(o),o.addFragmentCode(` +#define VOLUME_RENDERING true +`);let h=Ck,p=` + emitAccumAndRevealage(outputColor, 1.0 - revealage, 0u); +`,m=` +void emitIntensity(float value) { +} +`,g="";if(Xi(u.mode)){const v=u.mode===cn.MIN?"1.0 - value":"value";o.addFragmentCode(` +float savedDepth = 0.0; +float savedIntensity = 0.0; +vec4 newColor = vec4(0.0); +float userEmittedIntensity = -100.0; +`),m=` +float convertIntensity(float value) { + return clamp(${v}, 0.0, 1.0); +} +void emitIntensity(float value) { + userEmittedIntensity = value; +} +float getIntensity() { + float intensity = userEmittedIntensity > -100.0 ? userEmittedIntensity : defaultMaxProjectionIntensity; + return convertIntensity(intensity); +} +`,h=` +void emitRGBA(vec4 rgba) { + float alpha = clamp(rgba.a, 0.0, 1.0); + newColor = vec4(rgba.rgb * alpha, alpha); +} +`,p=` + gl_FragDepth = savedIntensity; +`,g=` + float newIntensity = getIntensity(); + bool intensityChanged = newIntensity > savedIntensity; + savedIntensity = intensityChanged ? newIntensity : savedIntensity; + savedDepth = intensityChanged ? depthAtRayPosition : savedDepth; + outputColor = intensityChanged ? newColor : outputColor; + emit(outputColor, savedDepth, savedIntensity, uPickId); + defaultMaxProjectionIntensity = 0.0; + userEmittedIntensity = -100.0; +`}if(a(o),o.addUniform("highp float","uNearLimitFraction"),o.addUniform("highp float","uFarLimitFraction"),o.addUniform("highp int","uMaxSteps"),o.addUniform("highp vec3","uTranslation"),o.addUniform("highp mat4","uModelViewProjectionMatrix"),o.addUniform("highp mat4","uInvModelViewProjectionMatrix"),o.addUniform("highp vec3","uChunkDataSize"),o.addUniform("highp float","uChunkNumber"),o.addUniform("highp vec3","uLowerClipBound"),o.addUniform("highp vec3","uUpperClipBound"),o.addUniform("highp float","uBrightnessFactor"),o.addUniform("highp float","uGain"),o.addUniform("highp uint","uPickId"),o.addVarying("highp vec4","vNormalizedPosition"),o.addTextureSampler("sampler2D","uDepthSampler",mu),o.addVertexCode(tL),o.setVertexMain(` +vec3 boxVertex = getBoxFaceVertexPosition(gl_VertexID); +vec3 position = max(uLowerClipBound, min(uUpperClipBound, uTranslation + boxVertex * uChunkDataSize)); +vNormalizedPosition = gl_Position = uModelViewProjectionMatrix * vec4(position, 1.0); +gl_Position.z = 0.0; +`),o.addFragmentCode(` +vec3 curChunkPosition; +float depthAtRayPosition; +vec4 outputColor; +float revealage; +void userMain(); +`),Ev(o,l,u.numChannelDimensions,"curChunkPosition"),o.addFragmentCode([m,h,` +void emitRGB(vec3 rgb) { + emitRGBA(vec4(rgb, 1.0)); +} +void emitGrayscale(float value) { + emitRGBA(vec4(value, value, value, value)); +} +void emitTransparent() { + emitIntensity(0.0); + emitRGBA(vec4(0.0, 0.0, 0.0, 0.0)); +} +float computeDepthFromClipSpace(vec4 clipSpacePosition) { + float NDCDepthCoord = clipSpacePosition.z / clipSpacePosition.w; + return (NDCDepthCoord + 1.0) * 0.5; +} +vec2 computeUVFromClipSpace(vec4 clipSpacePosition) { + vec2 NDCPosition = clipSpacePosition.xy / clipSpacePosition.w; + return (NDCPosition + 1.0) * 0.5; +} +`]),c){let v=` + emit(outputColor, 0u); +`;Xi(u.mode)&&(v=` + emit(outputColor, 1.0, uChunkNumber, uPickId); + `),o.setFragmentMainFunction(` +void main() { + outputColor = vec4(uChunkNumber, uChunkNumber, uChunkNumber, 1.0); + emitIntensity(uChunkNumber); + ${v} +} +`)}else o.setFragmentMainFunction(` +void main() { + vec2 normalizedPosition = vNormalizedPosition.xy / vNormalizedPosition.w; + vec4 nearPointH = uInvModelViewProjectionMatrix * vec4(normalizedPosition, -1.0, 1.0); + vec4 farPointH = uInvModelViewProjectionMatrix * vec4(normalizedPosition, 1.0, 1.0); + vec3 nearPoint = nearPointH.xyz / nearPointH.w; + vec3 farPoint = farPointH.xyz / farPointH.w; + vec3 rayVector = farPoint - nearPoint; + vec3 boxStart = max(uLowerClipBound, uTranslation); + vec3 boxEnd = min(boxStart + uChunkDataSize, uUpperClipBound); + float intersectStart = uNearLimitFraction; + float intersectEnd = uFarLimitFraction; + for (int i = 0; i < 3; ++i) { + float startPt = nearPoint[i]; + float endPt = farPoint[i]; + float boxLower = boxStart[i]; + float boxUpper = boxEnd[i]; + float r = rayVector[i]; + float startFraction; + float endFraction; + if (startPt >= boxLower && startPt <= boxUpper) { + startFraction = 0.0; + } else { + startFraction = min((boxLower - startPt) / r, (boxUpper - startPt) / r); + } + if (endPt >= boxLower && endPt <= boxUpper) { + endFraction = 1.0; + } else { + endFraction = max((boxLower - startPt) / r, (boxUpper - startPt) / r); + } + intersectStart = max(intersectStart, startFraction); + intersectEnd = min(intersectEnd, endFraction); + } + float stepSize = (uFarLimitFraction - uNearLimitFraction) / float(uMaxSteps - 1); + int startStep = int(floor((intersectStart - uNearLimitFraction) / stepSize)); + int endStep = min(uMaxSteps, int(floor((intersectEnd - uNearLimitFraction) / stepSize)) + 1); + outputColor = vec4(0, 0, 0, 0); + revealage = 1.0; + for (int rayStep = startStep; rayStep < endStep; ++rayStep) { + vec3 position = mix(nearPoint, farPoint, uNearLimitFraction + float(rayStep) * stepSize); + vec4 clipSpacePosition = uModelViewProjectionMatrix * vec4(position, 1.0); + depthAtRayPosition = computeDepthFromClipSpace(clipSpacePosition); + vec2 uv = computeUVFromClipSpace(clipSpacePosition); + float depthInBuffer = texture(uDepthSampler, uv).r; + bool rayPositionBehindOpaqueObject = (1.0 - depthAtRayPosition) < depthInBuffer; + if (rayPositionBehindOpaqueObject) { + break; + } + curChunkPosition = position - uTranslation; + userMain(); + ${g} + } + ${p} +} +`);o.addFragmentCode(Is),Ts(d,o),o.addFragmentCode(` +#define main userMain +`+ms(d.parseResult.code)+` +#undef main +`)}}),this.histogramShaderGetter=wo(this,this.gl,{memoizeKey:"VolumeRenderingRenderLayerHistogram",parameters:e.shaderControlState.builderState,getContextKey:({chunkFormat:o})=>`${o.shaderKey}`,shaderError:e.shaderError,extraParameters:t,defineShader:(o,{chunkFormat:a},l,c)=>{o.addOutputBuffer("vec4","outputValue",null),o.addUniform("highp vec3","uChunkDataSize"),o.addUniform("highp int","uHistogramIndex"),o.addAttribute("float","aInput1"),o.addVertexCode(` +vec3 chunkSamplePosition; + `);const d=c.numChannelDimensions;a.defineShader(o,d,!0);const{dataType:u}=a;let h="",p="";if(d===0)h+="highp int ignoredChannelIndex";else for(let S=0;S 1.0) x = 1.0; + else x = (1.0 + x * 253.0) / 255.0; + gl_Position = vec4(2.0 * (x * 255.0 + 0.5) / 256.0 - 1.0, 0.0, 0.0, 1.0); + } + gl_PointSize = 1.0;`),o.setFragmentMain(` +outputValue = vec4(1.0, 1.0, 1.0, 1.0); + `)}}),this.vertexIdHelper=this.registerDisposer(Qn.get(this.gl)),this.registerDisposer(this.depthSamplesTarget.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(this.gain.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(this.shaderControlState.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(this.localPosition.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(this.transform.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(this.mode.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(this.shaderControlState.fragmentMain.changed.add(this.redrawNeeded.dispatch));const{chunkManager:n}=this.multiscaleSource,s=this.registerDisposer(new Dr(this.layerChunkProgressInfo)),r=n.rpc;s.RPC_TYPE_ID=hk,s.initializeCounterpart(r,{chunkManager:n.rpcId,localPosition:this.registerDisposer(ft.makeFromExisting(r,this.localPosition)).rpcId,renderScaleTarget:this.registerDisposer(ft.makeFromExisting(r,this.depthSamplesTarget)).rpcId}),this.backend=s}get dataType(){return this.multiscaleSource.dataType}attach(e){super.attach(e),e.state={sources:e.registerDisposer((0,_.no)((t,n,s)=>{const r=sa(s,n,o=>this.multiscaleSource.getSources(o),e.messages,this);for(const o of r)for(const a of o)t.registerDisposer(a.source);return e.view.flushBackendProjectionParameters(),this.backend.rpc.invoke(pk,{layer:this.backend.rpcId,view:e.view.rpcId,sources:ta(r),displayDimensionRenderInfo:s}),this.redrawNeeded.dispatch(),r},this.transform,e.view.displayDimensionRenderInfo))}}get chunkManager(){return this.multiscaleSource.chunkManager}draw(e,t){if(!e.emitColor)return;const n=t.state.sources.value;if(n.length===0)return;let s=0,r=0,o={spatialScales:new Map,activeIndex:0},a=null,l,c;const d=C.eR.create(),{gl:u}=this;this.vertexIdHelper.enable(),this.modeOverride.value=cn.OFF;const{chunkResolutionHistogram:h}=this;h.begin(this.chunkManager.chunkQueueManager.frameNumberCounter.frameNumber);const p=()=>{const Y=!Xi(this.mode.value)&&!e.isContinuousCameraMotionInProgress;Xi(this.mode.value)||Y?(u.depthMask(!0),u.disable(WebGL2RenderingContext.BLEND),u.depthFunc(WebGL2RenderingContext.GREATER)):(u.depthMask(!1),u.enable(WebGL2RenderingContext.BLEND),u.depthFunc(WebGL2RenderingContext.LESS),e.bindVolumeRenderingBuffer())},m=()=>{if(a===null)return;a.unbindTransferFunctionTextures(),l!==null&&l.endDrawing(u,a);const Y=a.textureUnit(mu);if(u.activeTexture(WebGL2RenderingContext.TEXTURE0+Y),u.bindTexture(WebGL2RenderingContext.TEXTURE_2D,null),S!==0||w!==0){let Q=o.spatialScales.size-1;const X=new Set([fS(r)]);o.spatialScales.forEach((ce,oe)=>{const Se=fS(ce);Q!==o.activeIndex&&!X.has(Se)&&(h.add(oe,ce,0,yk,!0),X.add(Se)),Q--}),h.add(s,r,S,w)}};let g=!0;const{projectionParameters:v}=e;let y,S=0,w=0,b,x=1;const E=this.multiscaleSource.rank,D=C.eR.create(),I=this.getDataHistogramCount()>0&&!e.wireFrame&&!e.sliceViewsPresent&&!e.isContinuousCameraMotionInProgress,L=!Xi(this.mode.value)&&!e.isContinuousCameraMotionInProgress&&!e.wireFrame,k=Xi(this.mode.value)||L?e.pickIDs.register(this):0,O=[],V=[];let z;if(u.enable(WebGL2RenderingContext.CULL_FACE),u.cullFace(WebGL2RenderingContext.FRONT),uS(e.projectionParameters,this.localPosition.value,this.depthSamplesTarget.value,n[0],(Y,Q,X,ce,oe,Se)=>{s=X,r=ce,o=Se;const Ke=Mc(v,Y.chunkLayout),$e=Y.source,{fixedPositionWithinChunk:Tt,chunkDisplayDimensionIndices:we}=Y;for(const ls of we)Tt[ls]=0;const xe=$e.chunkFormat;if(xe!==l&&(l=xe,m(),c=this.shaderGetter({emitter:e.emitter,chunkFormat:xe,wireFrame:e.wireFrame}),a=c.shader,a!==null&&(a.bind(),xe!==null&&(vi(u,a,this.shaderControlState,c.parameters.parseResult.controls),this.bindDepthBufferTexture(e,a),xe.beginDrawing(u,a),xe.beginSource(u,a)))),b=void 0,a===null)return;y=$e.chunks,d.fill(1);const ct=C.pB.multiply(wk,v.viewProjectionMat,Ke.transform),dt=xk;(0,C._S)(dt,ct);const be=C.pB.create();C.pB.invert(be,ct);const{near:Ye,far:bt,adjustedNear:ni,adjustedFar:oo}=mk(dt,Y.lowerClipDisplayBound,Y.upperClipDisplayBound),vh=ce,yh=this.depthSamplesTarget.value,Sh=vh/yh,Dl=(ni-Ye)/(bt-Ye),as=(oo-Ye)/(bt-Ye);z={uNearLimitFraction:Dl,uFarLimitFraction:as,uMaxSteps:this.depthSamplesTarget.value,uBrightnessFactor:Sh,uGain:Math.exp(this.gain.value),uPickId:k,uLowerClipBound:Y.lowerClipDisplayBound,uUpperClipBound:Y.upperClipDisplayBound,uModelViewProjectionMatrix:ct,uInvModelViewProjectionMatrix:be},this.setShaderUniforms(a,z)},Y=>{if(a===null)return;const Q=Y.curPositionInChunks.join(),X=y.get(Q);if(X!==void 0&&X.state===Ue.GPU_MEMORY){const ce=Y.chunkLayout.size,oe=X.chunkDataSize,{chunkDisplayDimensionIndices:Se,fixedPositionWithinChunk:Ke,chunkTransform:{channelToChunkDimensionIndices:$e}}=Y;if(e.wireFrame){const we=x/y.size;u.uniform1f(a.uniform("uChunkNumber"),we),++x}if(oe!==b){b=oe;for(let we=0;we<3;++we){const xe=Se[we];d[we]=xe===-1||xe>=E?1:b[xe]}u.uniform3fv(a.uniform("uChunkDataSize"),d)}const{chunkGridPosition:Tt}=X;for(let we=0;we<3;++we){const xe=Se[we];D[we]=xe===-1||xe>=E?0:ce[we]*Tt[xe]}if(u.uniform3fv(a.uniform("uTranslation"),D),l?.bindChunk(u,a,X,Ke,Se,$e,g),(I||L)&&O.push({chunk:X,fixedPositionWithinChunk:Ke,chunkDisplayDimensionIndices:Se,channelToChunkDimensionIndices:$e,chunkDataDisplaySize:d,chunkFormat:l}),L){const we=C.eR.create(),xe=C.eR.create();C.eR.copy(we,d),C.eR.copy(xe,D),V.push({uChunkDataSize:we,uTranslation:xe})}Fv(u,1,1),g=!1,++S}else++w}),m(),a=null,l=null,L){u.enable(WebGL2RenderingContext.DEPTH_TEST),u.depthMask(!0),u.disable(WebGL2RenderingContext.BLEND),u.depthFunc(WebGL2RenderingContext.GREATER),e.emitter=e.maxProjectionEmit,e.bindMaxProjectionBuffer(),this.modeOverride.value=cn.MAX;const Y=()=>{a!==null&&(a.unbindTransferFunctionTextures(),l!==null&&l.endDrawing(u,a))};g=!0;for(let Q=0;Q{Y!==null&&(Y.unbindTransferFunctionTextures(),l!==null&&l.endDrawing(u,Y))},ce=(we,xe)=>{const ct=Math.ceil(we.reduce((Ye,bt)=>Ye*bt,1)/2),dt=Sk/xe,be=Math.min(ct,dt);return Math.max(Math.round(be/gu),1)};l=null;const{dataType:oe,dataHistogramSpecifications:Se}=this,Ke=Se.getFramebuffers(u),$e=this.getDataHistogramCount();for(let we=0;we<$e;++we)Ke[we].bind(256,1),u.clearColor(0,0,0,1),u.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT);const Tt=this.dataHistogramSpecifications.bounds.value;u.enable(WebGL2RenderingContext.BLEND),u.disable(WebGL2RenderingContext.DEPTH_TEST);for(let we=0;we{},r=>{const o=r.source.chunks.get(r.curPositionInChunks.join());(o===void 0||o.state!==Ue.GPU_MEMORY)&&(s=!0)}),!s}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Tk=Ae.fromObject({arrowup:{action:"tab-backward"},arrowdown:{action:"tab-forward"},tab:{action:"tab-forward"},"shift+tab":{action:"tab-backward"},enter:{action:"commit"},escape:{action:"cancel"}});class Dk{constructor(e){this.id=e,this.element=document.createElement("div"),this.nameContainer=document.createElement("div"),this.nameElement=document.createElement("input"),this.lowerElement=document.createElement("div"),this.upperElement=document.createElement("div");const{element:t,nameContainer:n,nameElement:s,lowerElement:r,upperElement:o}=this;t.classList.add("neuroglancer-channel-dimensions-widget-dim"),n.classList.add("neuroglancer-channel-dimensions-widget-name-container"),s.classList.add("neuroglancer-channel-dimensions-widget-name"),n.appendChild(s),r.classList.add("neuroglancer-channel-dimensions-widget-lower"),o.classList.add("neuroglancer-channel-dimensions-widget-upper"),t.appendChild(n),t.appendChild(r),t.appendChild(o),n.draggable=!0,s.disabled=!0,s.spellcheck=!1,s.autocomplete="off",s.required=!0,s.placeholder=" ",n.title="Drag to reorder, double click to rename. Names ending in ' or ^ indicate dimensions local to the layer; names ending in ^ indicate channel dimensions (image layers only).",n.addEventListener("dblclick",()=>{s.disabled=!1,s.focus(),s.select()}),s.addEventListener("focus",()=>{s.select()})}}class Ik extends T.O8{constructor(e){super(),this.combiner=e,this.element=document.createElement("div"),this.dimensionWidgets=[],this.curCoordinateSpace=void 0,this.dragSource=void 0,this.coordinateSpace=this.combiner.combined;const{element:t}=this;t.classList.add("neuroglancer-channel-dimensions-widget");const n=this.registerCancellable((0,Qe.t)(()=>this.updateView()));this.registerDisposer(e.combined.changed.add(n));const s=this.registerDisposer(new yn(t,Tk));s.allShortcutsAreGlobal=!0,this.registerDisposer(Z(t,"cancel",r=>{this.forceUpdateView();const{target:o}=r;o instanceof HTMLElement&&o.blur()})),this.updateView()}reorderDimensionTo(e,t){if(e===t)return;const{coordinateSpace:n}=this;n.value=Qh(n.value,e,t)}makeNewDimensionWidget(e){const t=new Dk(e);return t.nameContainer.addEventListener("dragstart",n=>{this.dragSource=t,n.stopPropagation(),n.dataTransfer.setData("neuroglancer-dimension","")}),t.nameContainer.addEventListener("dragenter",n=>{const{dragSource:s}=this;if(s===void 0||s===t)return;const{dimensionWidgets:r}=this,o=r.indexOf(s),a=r.indexOf(t);o===-1||a===-1||(n.preventDefault(),this.reorderDimensionTo(a,o))}),t.nameContainer.addEventListener("dragend",n=>{this.dragSource===t&&(this.dragSource=void 0)}),t.nameElement.addEventListener("blur",n=>{t.nameElement.disabled=!0;const{relatedTarget:s}=n;this.dimensionWidgets.some(r=>r.nameElement===s)||this.updateNames()||this.forceUpdateView()}),t.nameElement.addEventListener("input",()=>{const{nameElement:n}=t;$t(n),this.updateNameValidity()}),Z(t.nameElement,"commit",()=>{this.updateNames()}),Z(t.nameElement,"tab-forward",n=>this.selectAdjacentField(n,t,1)),Z(t.nameElement,"tab-backward",n=>this.selectAdjacentField(n,t,-1)),t}selectAdjacentField(e,t,n){e.stopPropagation();const{dimensionWidgets:s}=this,r=s.indexOf(t);if(r===-1)return;const o=r+n;if(o<0||o>=s.length)return;const a=s[o];a.nameElement.disabled=!1,a.nameElement.focus(),e.preventDefault()}updateNames(){const{dimensionWidgets:e,coordinateSpace:t}=this,n=t.value,s=e.map(l=>l.nameElement.value);if(this.combiner.getRenameValidity(s).includes(!1))return!1;const r=n.names;if((0,F.r1)(r,s))return!1;const o=n.timestamps.map((l,c)=>r[c]===s[c]?l:Date.now()),a={...n,names:s,timestamps:o};return t.value=a,!0}updateNameValidity(){const{dimensionWidgets:e}=this,t=e.map(r=>r.nameElement.value),n=t.length,s=this.combiner.getRenameValidity(t);for(let r=0;rn.find(a=>a.id===o)||this.makeNewDimensionWidget(o));function*r(){const{names:o,rank:a,bounds:l}=e;for(let c=0;cbo(()=>MC(t)),this.channelCoordinateSpace)),this.volumeRenderingMode=cS(),this.shaderControlState=this.registerDisposer(new Jo(this.fragmentMain,this.registerDisposer((0,_.Uq)((t,n)=>t===void 0?null:{imageData:{dataType:t,channelRank:n.rank}},[this.dataType,this.channelCoordinateSpace],(t,n)=>JSON.stringify(t)===JSON.stringify(n))),this.channelCoordinateSpaceCombiner)),this.localCoordinateSpaceCombiner.includeDimensionPredicate=rr,this.blendMode.changed.add(this.specificationChanged.dispatch),this.opacity.changed.add(this.specificationChanged.dispatch),this.volumeRenderingGain.changed.add(this.specificationChanged.dispatch),this.fragmentMain.changed.add(this.specificationChanged.dispatch),this.shaderControlState.changed.add(this.specificationChanged.dispatch),this.sliceViewRenderScaleTarget.changed.add(this.specificationChanged.dispatch),this.volumeRenderingMode.changed.add(this.specificationChanged.dispatch),this.volumeRenderingDepthSamplesTarget.changed.add(this.specificationChanged.dispatch),this.tabs.add("rendering",{label:"Rendering",order:-100,getter:()=>new kk(this)}),this.tabs.default="rendering"}markLoading(){const e=super.markLoading(),t=this.channelCoordinateSpaceCombiner.retain();return()=>{e(),t()}}addCoordinateSpace(e){const t=super.addCoordinateSpace(e),n=this.channelCoordinateSpaceCombiner.bind(e);return()=>{t(),n()}}activateDataSubsources(e){let t;for(const n of e){if(this.addStaticAnnotations(n))continue;const{subsourceEntry:s}=n,{subsource:r}=s,{volume:o}=r;if(!(o instanceof ln)){n.deactivate("Not compatible with image layer");continue}if(t&&o.dataType!==t){n.deactivate(`Data type must be ${R[o.dataType].toLowerCase()}`);continue}t=o.dataType,n.activate(a=>{n.addRenderLayer(new dk(o,{opacity:this.opacity,blendMode:this.blendMode,shaderControlState:this.shaderControlState,shaderError:this.shaderError,transform:n.getRenderLayerTransform(this.channelCoordinateSpace),renderScaleTarget:this.sliceViewRenderScaleTarget,renderScaleHistogram:this.sliceViewRenderScaleHistogram,localPosition:this.localPosition,channelCoordinateSpace:this.channelCoordinateSpace}));const l=a.registerDisposer(new Ek({gain:this.volumeRenderingGain,multiscaleSource:o,shaderControlState:this.shaderControlState,shaderError:this.shaderError,transform:n.getRenderLayerTransform(this.channelCoordinateSpace),depthSamplesTarget:this.volumeRenderingDepthSamplesTarget,chunkResolutionHistogram:this.volumeRenderingChunkResolutionHistogram,localPosition:this.localPosition,channelCoordinateSpace:this.channelCoordinateSpace,mode:this.volumeRenderingMode}));a.registerDisposer(n.messages.addChild(l.messages)),a.registerDisposer((0,_.no)((c,d)=>{d!==cn.OFF&&c.registerDisposer(this.addRenderLayer(l.addRef()))},this.volumeRenderingMode)),this.shaderError.changed.dispatch()})}this.dataType.value=t}restoreState(e){super.restoreState(e),this.opacity.restoreState(e[vu]),(0,f.MM)(e,yu,t=>this.blendMode.restoreState(t)),this.fragmentMain.restoreState(e[gS]),this.shaderControlState.restoreState(e[mS]),this.sliceViewRenderScaleTarget.restoreState(e[Su]),this.channelCoordinateSpace.restoreState(e[vS]),(0,f.MM)(e,bu,t=>{typeof t=="boolean"?this.volumeRenderingMode.value=t?cn.ON:cn.OFF:this.volumeRenderingMode.restoreState(t)}),(0,f.MM)(e,Cu,t=>this.volumeRenderingGain.restoreState(t)),(0,f.MM)(e,wu,t=>this.volumeRenderingDepthSamplesTarget.restoreState(t))}toJSON(){const e=super.toJSON();return e[vu]=this.opacity.toJSON(),e[yu]=this.blendMode.toJSON(),e[gS]=this.fragmentMain.toJSON(),e[mS]=this.shaderControlState.toJSON(),e[Su]=this.sliceViewRenderScaleTarget.toJSON(),e[vS]=this.channelCoordinateSpace.toJSON(),e[bu]=this.volumeRenderingMode.toJSON(),e[Cu]=this.volumeRenderingGain.toJSON(),e[wu]=this.volumeRenderingDepthSamplesTarget.toJSON(),e}displayImageSelectionState(e,t){const{value:n}=e;if(n==null)return!1;const s=this.channelSpace.value;if(s.error!==void 0)return!1;const{numChannels:r,coordinates:o,channelCoordinateSpace:{names:a,rank:l}}=s,c=document.createElement("div");c.classList.add("neuroglancer-selection-details-value-grid");let d="[copy] 0fr ";l!==0&&(d+=`repeat(${l}, [dim] 0fr [coord] 0fr) `),d+="[value] 1fr",c.style.gridTemplateColumns=d;for(let u=0;u{mi(p)}});c.appendChild(m);for(let v=0;ve.key,defineShader:(e,t)=>{e.addFragmentCode(` +#define uOpacity 1.0 +`),lS(e,t)},initializeShader:e=>{const t=e.shader;vi(this.manager.root.display.gl,t,this.shaderControlState,e.parameters.parseResult.controls)}}}}Zi.type="image",Zi.typeAbbreviation="img";function SS(i){return new Ja({shaderError:i.shaderError,fragmentMain:i.fragmentMain,shaderControlState:i.shaderControlState})}const bS=[{label:"Resolution (slice)",toolJson:Su,...ma(i=>({histogram:i.sliceViewRenderScaleHistogram,target:i.sliceViewRenderScaleTarget}))},{label:"Blending (slice)",toolJson:yu,...md(i=>i.blendMode)},{label:"Opacity (slice)",toolJson:vu,...Yn(i=>({value:i.opacity}))},{label:"Volume rendering (experimental)",toolJson:bu,...md(i=>i.volumeRenderingMode)},{label:"Gain (3D)",toolJson:Cu,isValid:i=>(0,_.Uq)(e=>e===cn.ON,[i.volumeRenderingMode]),...Yn(i=>({value:i.volumeRenderingGain,options:{min:-10,max:10,step:.1}}))},{label:"Resolution (3D)",toolJson:wu,isValid:i=>(0,_.Uq)(e=>e!==cn.OFF,[i.volumeRenderingMode]),...ma(i=>({histogram:i.volumeRenderingChunkResolutionHistogram,target:i.volumeRenderingDepthSamplesTarget}),eD)}];for(const i of bS)gd(Zi,i);class kk extends Gt{constructor(e){super(),this.layer=e,this.codeWidget=this.registerDisposer(SS(this.layer));const{element:t}=this;t.classList.add("neuroglancer-image-dropdown");for(const r of bS)t.appendChild(fa(this,e,this.visibility,r));const n=document.createElement("div");n.style.flex="1";const s=document.createElement("div");s.className="neuroglancer-image-dropdown-top-row",s.appendChild(document.createTextNode("Shader")),s.appendChild(n),s.appendChild(Ha({title:"Show larger editor view",onClick:()=>{new Pk(this.layer)}})),s.appendChild(Wa({title:"Documentation on image layer rendering",href:"https://github.com/google/neuroglancer/blob/master/src/sliceview/image_layer_rendering.md"})),t.appendChild(s),t.appendChild(this.registerDisposer(new Ik(e.channelCoordinateSpaceCombiner)).element),t.appendChild(this.codeWidget.element),t.appendChild(this.registerDisposer(new ja(e.shaderControlState,this.layer.manager.root.display,this.layer,{visibility:this.visibility,legendShaderOptions:this.layer.getLegendShaderOptions()})).element)}}class Pk extends Jr{constructor(e){super(),this.layer=e,this.codeWidget=this.registerDisposer(SS(this.layer)),this.content.classList.add("neuroglancer-image-layer-shader-overlay"),this.content.appendChild(this.codeWidget.element),this.codeWidget.textEditor.refresh()}}$i(Zi),Hg(St.IMAGE,Zi),da(i=>{const{volume:e}=i;if(e!==void 0&&e.volumeType===St.UNKNOWN)return{layerConstructor:Zi,priority:-100}}),Ya(Zi,i=>({shaderControlState:i.shaderControlState,legendShaderOptions:i.getLegendShaderOptions()}));var CS=G(957),Ak=Object.defineProperty,Mk=Object.getOwnPropertyDescriptor,Nk=(i,e,t,n)=>{for(var s=n>1?void 0:n?Mk(e,t):e,r=i.length-1,o;r>=0;r--)(o=i[r])&&(s=(n?o(e,t,s):o(s))||s);return n&&s&&Ak(e,t,s),s};/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */let xu=class extends hn{constructor(i,e){super(),this.provider=i,this.registerDisposer(i),this.initializeCounterpart(e)}get(i,e){return this.provider.get(i,e)}};xu=Nk([Zt(CS.P)],xu),pp(CS.y,function(i,e){return this.get(i.providerId).get(i.invalidCredentials,e).then(n=>({value:n}))});/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Eu(i,e){if(e===void 0)return;const t=i.memoize.get({type:"getSharedCredentialsProvider",credentialsProvider:xt(e)},()=>new xu(e.addRef(),i.rpc)),n=t.addCounterpartRef();return t.dispose(),n}function lt(){return i=>{class e extends i{constructor(...n){super(...n);const s=n[1];this.credentialsProvider=s.credentialsProvider?.addRef()}initializeCounterpart(n,s){const{credentialsProvider:r}=this;s.credentialsProvider=Eu(this.chunkManager,r),super.initializeCounterpart(n,s)}static encodeOptions(n){const s=i.encodeOptions(n),{credentialsProvider:r}=n;return s.credentialsProvider=r===void 0?void 0:xt(r),s}}return e}}var Hs=G(6015);const wS=!1;var Js=G(3551),ke=G(9808);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */async function Ok(i,e,t,n,s){const r=await(0,Js.Y)(i,`${e}?prefix=${encodeURIComponent(t)}&delimiter=${encodeURIComponent(n)}`,{},d=>d.text(),s),o=new DOMParser().parseFromString(r,"application/xml"),a=o.evaluate('//*[name()="CommonPrefixes"]/*[name()="Prefix"]',o,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null),l=[];for(let d=0,u=a.snapshotLength;d({value:l.substring(a)}))}}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */async function _k(i,e,t,n,s=Je.fx){return await(0,ke.Bk)(`https://${i}.s3.amazonaws.com${e}`,t,n,s)}async function Vk(i,e,t){return await Tu(void 0,`s3://${i}`,`https://${i}.s3.amazonaws.com`,e,t)}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Bk(i,e){return i.getCredentialsProvider("middleauthapp",new URL(e).origin)}function Qa(i,e,t){const n=/^\/([^/]+)/,s=t.match(n);if(s!==null)return wS?i.getCredentialsProvider("gcs",{bucket:s[1]}):i.getCredentialsProvider("ngauth_gcs",{authServer:e,bucket:s[1]})}function wn(i,e){const t=(0,ke.Dl)(i);switch(t.protocol){case"gs":case"gs+xml":return{credentialsProvider:wS?e.getCredentialsProvider("gcs",{bucket:t.host}):void 0,url:i};case"gs+ngauth+http":return{credentialsProvider:Qa(e,`http://${t.host}`,t.path),url:"gs:/"+t.path};case"gs+ngauth+https":return{credentialsProvider:Qa(e,`https://${t.host}`,t.path),url:"gs:/"+t.path};case"gs+xml+ngauth+http":return{credentialsProvider:Qa(e,`http://${t.host}`,t.path),url:"gs+xml:/"+t.path};case"gs+xml+ngauth+https":return{credentialsProvider:Qa(e,`https://${t.host}`,t.path),url:"gs+xml:/"+t.path};case"middleauth+https":return i=i.substr(11),{credentialsProvider:Bk(e,i),url:i};case"s3":return{credentialsProvider:void 0,url:i};default:return{credentialsProvider:void 0,url:i}}}async function Nt(i,e,t,n,s=Je.fx){const r=(0,ke.Dl)(e);switch(r.protocol){case"gs":return(0,Js.Y)(i,`https://www.googleapis.com/storage/v1/b/${r.host}/o/${encodeURIComponent(r.path.substring(1))}?alt=media&neuroglancer=${Te()}`,t,n,s);case"gs+xml":return(0,Js.Y)(i,`https://storage.googleapis.com/${r.host}${r.path}?neuroglancer=${Te()}`,t,n,s);case"s3":return _k(r.host,r.path,t,n,s);default:return(0,Js.Y)(i,e,t,n,s)}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Fk extends T.O8{constructor(e){super(),this.gl=e,this.buffer=this.registerDisposer(new At(e))}resize(e){let t;if(e<256){const n=t=new Uint8Array(e);for(let s=0;s=0&&(this.bindToVertexAttrib(n),t!==0&&this.gl.vertexAttribDivisor(n,t))}}function Uk(i,e,t=!1){const n=e.attribute("aIndexRaw");n>=0&&(t&&i.vertexAttribDivisor(n,0),i.disableVertexAttribArray(n))}function $k(i){return i.memoize.get("IndexBuffer",()=>new Fk(i))}function Gk(i){i.addAttribute("highp uint","aIndexRaw"),i.addVertexCode(To),i.addVertexCode(` +uint getPrimitiveIndex() { + return aIndexRaw; +} +`)}class zk{constructor(e){this.name=e}defineShader(e){e.addAttribute("highp uint",this.name)}bind(e,t){const n=t.attribute(this.name);e.bindToVertexAttribI(n,1,WebGL2RenderingContext.UNSIGNED_INT)}disable(e){e.gl.disableVertexAttribArray(e.attribute(this.name))}}function Wk(i,e){return At.fromData(i,e,WebGL2RenderingContext.ARRAY_BUFFER,WebGL2RenderingContext.STATIC_DRAW)}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const xS=`void main() { + emitGray(); +} +`;class Hk{constructor(){this.shaderError=dr(),this.fragmentMain=Co(xS),this.shaderControlState=new Jo(this.fragmentMain)}}function ES(i){return yt(i.dataType,i.numComponents)}const es=[],TS=Wi(new Ns,R.FLOAT32,3),Jk=TS;function jk(i){return i.split(/[^a-zA-Z0-9]+/).filter(e=>e).join("_")}function DS(i){const e=new Set,t=[];for(const n of i){const s=jk(n);let r="",o=0;for(;e.has(s+r);)r=""+ ++o;t.push(s+r)}return t}class Yk{constructor(e,t){this.attributeNames=e,this.attributeInfo=t,this.tempLightVec=new Float32Array(4),this.textureAccessHelper=new xa("vertexData"),this.indexBufferHelper=new zk("vertexIndex")}defineAttributeAccess(e,t){const{textureAccessHelper:n}=this;n.defineShader(e);const{attributeNames:s}=this;let r=2+s.length;for(let a=es.length;a{e.addTextureSampler(`${Ca(a.dataType)}sampler2D`,`uVertexAttributeSampler${r}`,es[r]);const c=ES(a);e.addVarying(`highp ${c}`,`vCustom${l}`),e.addFragmentCode(` +#define ${s[l]} vCustom${l} +`),e.addVertexCode(n.getAccessor(`readAttribute${l}`,`uVertexAttributeSampler${r}`,a.dataType,a.numComponents)),o+=`vCustom${l} = readAttribute${l}(${t}); +`,++r}),e.addVertexMain(o)}defineShader(e){e.require(Gk),this.indexBufferHelper.defineShader(e),e.addVarying("highp float","vLightingFactor"),e.addUniform("highp vec4","uLightDirection"),e.addUniform("highp vec4","uColor"),e.addUniform("highp mat4","uModelMatrix"),e.addUniform("highp mat4","uProjection"),e.addUniform("highp uint","uPickID"),e.addVarying("highp uint","vPickID","flat"),e.addVertexMain(` +uint triangleIndex = getPrimitiveIndex() / 3u; +vPickID = uPickID + triangleIndex; +`),e.addFragmentCode(` +void emitPremultipliedRGBA(vec4 color) { + emit(vec4(color.rgb * vLightingFactor, color.a), vPickID); +} +void emitRGBA(vec4 color) { + color = clamp(color, 0.0, 1.0); + color.xyz *= color.a; + emitPremultipliedRGBA(color); +} +void emitRGB(vec3 color) { + emitRGBA(vec4(color, 1.0)); +} +void emitGray() { + emitRGB(vec3(1.0, 1.0, 1.0)); +} +`),e.addFragmentCode(Is),this.defineAttributeAccess(e,"vertexIndex"),e.addVertexMain(` +gl_Position = uProjection * (uModelMatrix * vec4(vertexPosition, 1.0)); +vec3 normal = normalize((uModelMatrix * vec4(vertexNormal, 0.0)).xyz); +vLightingFactor = abs(dot(normal, uLightDirection.xyz)) + uLightDirection.w; +`)}beginLayer(e,t,n){const{lightDirection:s,ambientLighting:r,directionalLighting:o,projectionParameters:a}=n,{viewProjectionMat:l}=a;e.uniformMatrix4fv(t.uniform("uProjection"),!1,l);const c=this.tempLightVec;C.eR.scale(c,s,o),c[3]=r,e.uniform4fv(t.uniform("uLightDirection"),c)}setPickID(e,t,n){e.uniform1ui(t.uniform("uPickID"),n)}beginObject(e,t,n){e.uniformMatrix4fv(t.uniform("uModelMatrix"),!1,n)}bindVertexData(e,t,n){let s=0;const r=a=>{const l=WebGL2RenderingContext.TEXTURE0+t.textureUnit(es[s]);e.activeTexture(l),e.bindTexture(WebGL2RenderingContext.TEXTURE_2D,a),++s};r(n.vertexTexture),r(n.normalTexture);const{attributeNames:o}=this;n.vertexAttributeTextures.forEach((a,l)=>{o[l]!==void 0&&r(a)})}disableVertexData(e,t){let n=2;const s=this.attributeInfo.length,{attributeNames:r}=this;for(let o=0;o{const o=e.createTexture();return e.bindTexture(WebGL2RenderingContext.TEXTURE_2D,o),wa(e,r,s),o};this.vertexTexture=n(this.vertexPositions,TS),this.normalTexture=n(this.vertexNormals,Jk),this.vertexAttributeTextures=this.vertexAttributes.map((s,r)=>n(s,t[r])),e.bindTexture(WebGL2RenderingContext.TEXTURE_2D,null)}freeGPUMemory(e){e.deleteTexture(this.vertexTexture),e.deleteTexture(this.normalTexture);const{vertexAttributeTextures:t}=this;for(const n of t)e.deleteTexture(n);t.length=0}}class Kk extends Jn{constructor(e,t){super(e);const n=this.vertexData=new Qk;n.vertexPositions=t.vertexPositions,n.vertexNormals=t.vertexNormals,n.vertexAttributes=t.vertexAttributes;const s=this.indices=t.indices;this.numIndices=s.length}copyToGPU(e){super.copyToGPU(e),this.vertexData.copyToGPU(e,this.source.attributeTextureFormats),this.indexBuffer=Wk(e,this.indices)}freeGPUMemory(e){super.freeGPUMemory(e),this.vertexData.freeGPUMemory(e),this.indexBuffer.dispose()}}function qk(i){return i.map(e=>Wi(new Ns,e.dataType,e.numComponents))}class Xk extends it(lt()(on),Hs.Fe){constructor(){super(...arguments),this.attributeTextureFormats=qk(this.info.vertexAttributes)}get info(){return this.parameters.info}getChunk(e){return new Kk(this,e)}}const Zk=ar(hn);class eP extends Zk{}class tP extends Gi{constructor(e,t,n){super(),this.source=e,this.displayState=t,this.transform=n,this.shaderManager=new Yk(DS(this.source.info.vertexAttributes.map(r=>r.name)),this.source.info.vertexAttributes),this.shaders=new Map,this.sharedObject=this.registerDisposer(new eP),this.shaderGetter=Ai(this,this.gl,{memoizeKey:{t:"single_mesh/RenderLayer",attributes:this.source.info.vertexAttributes},fallbackParameters:new _.B0(Ho(Er(xS))),parameters:this.displayState.shaderControlState.builderState,encodeParameters:r=>r.key,shaderError:this.displayState.shaderError,defineShader:(r,o)=>{if(o.parseResult.errors.length!==0)throw new Error("Invalid UI control specification");Ts(o,r),this.shaderManager.defineShader(r),r.setFragmentMainFunction(ms(o.parseResult.code))}}),this.countingBuffer=this.registerDisposer($k(this.gl)),this.registerDisposer(t.shaderControlState.parseResult.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(t.shaderControlState.changed.add(this.redrawNeeded.dispatch)),this.registerDisposer(n.changed.add(this.redrawNeeded.dispatch));const{sharedObject:s}=this;s.visibility.add(this.visibility),s.RPC_TYPE_ID=Hs.nG,s.initializeCounterpart(e.chunkManager.rpc,{chunkManager:e.chunkManager.rpcId,source:e.addCounterpartRef()})}disposeShaders(){const{shaders:e}=this;for(const t of e.values())t!==null&&t.dispose();e.clear()}disposed(){this.disposeShaders(),super.disposed()}get isTransparent(){return this.displayState.fragmentMain.value.match(/emitRGBA|emitPremultipliedRGBA/)!==null}get gl(){return this.source.gl}isReady(){const e=this.source.chunks.get(Hs.b7);return!(e===void 0||e.state!==Ue.GPU_MEMORY)}draw(e,t){if(!e.emitColor&&e.alreadyEmittedPickID)return;const n=lr(this.transform.value,e.projectionParameters.displayDimensionRenderInfo,t);if(n===void 0)return;const s=this.source.chunks.get(Hs.b7);if(s===void 0||s.state!==Ue.GPU_MEMORY)return;const r=this.shaderGetter(e.emitter),{shader:o,parameters:a}=r;if(o===null)return;const{gl:l}=this,c=this.shaderManager;o.bind(),c.beginLayer(l,o,e),vi(l,o,this.displayState.shaderControlState,a.parseResult.controls);const{pickIDs:d}=e;c.beginObject(l,o,n),e.emitPickID&&c.setPickID(l,o,d.register(this,s.numIndices/3)),c.drawFragment(l,o,s,this.countingBuffer),c.endLayer(l,o)}transformPickedValue(e){const{pickedOffset:t}=e,n=this.source.chunks.get(Hs.b7);if(n===void 0)return;const s=t*3,{indices:r}=n;if(s>=r.length)return;const o=r[s],a=[],{attributeNames:l}=this.shaderManager;return n.vertexData.vertexAttributes.forEach((c,d)=>{const u=l[d];u!==void 0&&a.push(`${u}=${c[o].toPrecision(6)}`)}),a.join(", ")}}function nP(i,e,t){return i.memoize.getUncounted({type:"single_mesh:getMeshInfo",url:t},async()=>{const{url:n,credentialsProvider:s}=wn(t,e);return{info:await i.rpc.promiseInvoke(Hs.N3,{chunkManager:i.addCounterpartRef(),credentialsProvider:Eu(i,s),parameters:{meshSourceUrl:n}}),url:n,credentialsProvider:s}})}async function IS(i,e,t){const{info:n,url:s,credentialsProvider:r}=await nP(i,e,t);return i.getChunkSource(Xk,{credentialsProvider:r,parameters:{meshSourceUrl:s,info:n}})}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const LS="shader",RS="shaderControls";class Kr extends Rn{constructor(e){super(e),this.managedLayer=e,this.displayState=new Hk,this.vertexAttributes=new _.B0(void 0),this.registerDisposer(this.displayState.shaderControlState.changed.add(this.specificationChanged.dispatch)),this.registerDisposer(this.displayState.fragmentMain.changed.add(this.specificationChanged.dispatch)),this.tabs.add("rendering",{label:"Rendering",order:-100,getter:()=>new sP(this)}),this.tabs.default="rendering"}restoreState(e){super.restoreState(e),this.displayState.fragmentMain.restoreState(e[LS]),this.displayState.shaderControlState.restoreState(e[RS])}activateDataSubsources(e){let t=!1;for(const n of e){const{subsourceEntry:s}=n,{subsource:r}=s,{singleMesh:o}=r;if(o!==void 0){if(t){n.deactivate("Only one single-mesh source supported");continue}t=!0,n.activate(a=>{n.addRenderLayer(new tP(o,this.displayState,n.getRenderLayerTransform())),this.vertexAttributes.value=o.info.vertexAttributes,a.registerDisposer(()=>{this.vertexAttributes.value=void 0})});continue}n.deactivate("Not compatible with image layer")}}toJSON(){const e=super.toJSON();return e[LS]=this.displayState.fragmentMain.toJSON(),e[RS]=this.displayState.shaderControlState.toJSON(),e}}Kr.type="mesh",Kr.typeAbbreviation="mesh";function kS(i){return new Ja({fragmentMain:i.displayState.fragmentMain,shaderError:i.displayState.shaderError,shaderControlState:i.displayState.shaderControlState})}class iP extends T.O8{constructor(e){super(),this.attributes=e,this.element=document.createElement("div"),this.element.className="neuroglancer-single-mesh-attribute-widget",this.updateView(),this.registerDisposer(e.changed.add(()=>{this.updateView()}))}updateView(){const{element:e}=this,t=this.attributes.value;if(t===void 0){Me(e);return}const n=DS(t.map(r=>r.name)),s=t.length;for(let r=0;r{new rP(this.layer)}})),n.appendChild(Wa({title:"Documentation on single mesh layer rendering",href:"https://github.com/google/neuroglancer/blob/master/src/sliceview/image_layer_rendering.md"})),t.appendChild(n),t.appendChild(this.attributeWidget.element),t.appendChild(this.codeWidget.element),t.appendChild(this.registerDisposer(new ja(e.displayState.shaderControlState,this.layer.manager.root.display,this.layer,{visibility:this.visibility})).element)}}class rP extends Jr{constructor(e){super(),this.layer=e,this.attributeWidget=this.registerDisposer(PS(this.layer)),this.codeWidget=this.registerDisposer(kS(this.layer)),this.content.classList.add("neuroglancer-single-mesh-layer-shader-overlay"),this.content.appendChild(this.attributeWidget.element),this.content.appendChild(this.codeWidget.element),this.codeWidget.textEditor.refresh()}}$i(Kr),da(i=>{if(i.singleMesh!==void 0)return{layerConstructor:Kr,priority:2}}),Ya(Kr,i=>({shaderControlState:i.displayState.shaderControlState}));var Ka=G(2366);/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const AS="boss";function js(i,e,t,n,s=Je.fx){return(0,ke.Bk)(e,t,n,s).catch(r=>{if(r.status!==500&&r.status!==401&&r.status!==403&&r.status!==504)throw r;return(0,Ka.R)(i,e,t,n,o=>{const a=new Headers(t.headers);return a.set("Authorization",`Bearer ${o}`),{...t,headers:a}},o=>{const{status:a}=o;if(a===403||a===401)return"refresh";throw o},s)})}var MS=G(6650);/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class oP extends it(lt()(Kn),MS.jj){}class aP extends it(lt()(Qi),MS.Ve){}const Du=new Map;Du.set("image",St.IMAGE),Du.set("annotation",St.SEGMENTATION);const lP=new Set(["npz","jpeg"]),cP=Uint32Array.of(512,512,16);var NS=(i=>(i[i.NANOMETERS=0]="NANOMETERS",i[i.MICROMETERS=1]="MICROMETERS",i[i.MILLIMETERS=2]="MILLIMETERS",i[i.CENTIMETERS=3]="CENTIMETERS",i))(NS||{});function dP(i){switch(i){case 1:return 1e6;case 2:return 1e3;case 3:return 100;case 0:return 1e9}}function uP(i,e){(0,f.Rf)(i);const t=(0,f.cQ)(i,"voxel_unit",c=>(0,f.sl)(c,NS)),n=dP(t),s=new Float32Array(3),r=new Float64Array(3),o=new Float64Array(3),a=new Float64Array(3),l=["x","y","z"];for(let c=0;c<3;++c){const d=l[c];s[c]=(0,f.cQ)(i,`${d}_voxel_size`,f.Mo),r[c]=s[c]/n,o[c]=(0,f.cQ)(i,`${d}_start`,f.bX),a[c]=(0,f.cQ)(i,`${d}_stop`,f.bX)}return e.coordFrame={voxelSizeBaseInMeters:r,voxelSizeBaseInOriginalUnits:s,voxelOffsetBase:o,imageSizeBase:a,voxelUnit:t,names:l},e}function hP(i){let e=Du.get(i);return e===void 0&&(e=St.UNKNOWN),e}function pP(i){(0,f.Rf)(i);const e=(0,f.cQ)(i,"type",f.zr);let t=!1;return(0,f.cQ)(i,"downsample_status",f.zr)==="DOWNSAMPLED"&&(t=!0),{channelType:e,description:(0,f.cQ)(i,"description",f.zr),volumeType:hP(e),dataType:(0,f.cQ)(i,"datatype",s=>(0,f.sl)(s,R)),downsampled:t,scales:[],key:(0,f.cQ)(i,"name",f.zr),baseResolution:(0,f.cQ)(i,"base_resolution",f.bX)}}function fP(i,e,t,n,s,r){(0,f.Rf)(i);const o=(0,f.cQ)(i,"channels",a=>(0,f.$v)(a,l=>vP(e,t,n,r,s,l)));return Promise.all(o).then(a=>{const l=new Map;a.forEach(d=>{l.set(d.key,d)});const c={channels:l,scalingLevels:(0,f.cQ)(i,"num_hierarchy_levels",f.bX),coordFrameKey:(0,f.cQ)(i,"coord_frame",f.zr),coordFrame:void 0,key:(0,f.cQ)(i,"name",f.zr),collection:(0,f.cQ)(i,"collection",f.zr)};return EP(e,t,n,c)})}class gP extends ln{constructor(e,t,n,s,r,o){if(super(e),this.baseUrl=t,this.credentialsProvider=n,this.experimentInfo=s,this.parameters=o,this.meshPath=void 0,this.meshUrl=void 0,r===void 0){const u=Array.from(s.channels.keys());if(u.length!==1)throw new Error(`Experiment contains multiple channels: ${JSON.stringify(u)}`);r=u[0]}const a=s.channels.get(r);if(a===void 0)throw new Error(`Specified channel ${JSON.stringify(r)} is not one of the supported channels ${JSON.stringify(Array.from(s.channels.keys()))}`);if(this.channel=r,this.channelInfo=a,this.scales=a.scales,s.coordFrame===void 0)throw new Error(`Specified experiment ${JSON.stringify(s.key)} does not have a valid coordinate frame`);this.coordinateFrame=s.coordFrame,this.channelInfo.downsampled===!1&&(this.scales=[a.scales[0]]),this.experiment=s.key;const l=(0,f.z$)(o.window);if(l!==void 0){const u=C.Zc.create(),h=l.split(/,/);if(h.length===2)u[0]=(0,f.zo)(h[0]),u[1]=(0,f.zo)(h[1]);else if(h.length===1)u[0]=0,u[1]=(0,f.zo)(h[1]);else throw new Error(`Invalid window. Must be either one value or two comma separated values: ${JSON.stringify(l)}`);if(this.window=u,this.window[0]===this.window[1])throw new Error(`Invalid window. First element must be different from second: ${JSON.stringify(l)}.`)}const c=(0,f.z$)(o.meshurl);c!==void 0&&(this.meshUrl=c);let d=(0,f.z$)(o.encoding);if(d===void 0)d=this.dataType===R.UINT8?"jpeg":"npz";else if(!lP.has(d))throw new Error(`Invalid encoding: ${JSON.stringify(d)}.`);this.encoding=d}get dataType(){return this.channelInfo.dataType}get volumeType(){return this.channelInfo.volumeType}get rank(){return 3}getSources(e){const t=this.scales[0].downsampleFactors,{rank:n}=this;return(0,F.RO)(this.scales.map(s=>{const r=this.coordinateFrame.voxelOffsetBase,o=C.eR.create();for(let u=0;u<3;++u)o[u]=Math.ceil(r[u]);const a=s.downsampleFactors,l=n+1,c=new Float32Array(l*l);c[c.length-1]=1;for(let u=0;u<3;++u){const h=a[u]/t[u];c[l*u+u]=h,c[l*n+u]=o[u]*h}n===4&&(c[l*3+3]=1);const d=s.imageSize;return qi({rank:3,volumeType:this.volumeType,dataType:this.dataType,chunkToMultiscaleTransform:c,chunkDataSizes:[cP],baseVoxelOffset:o,upperVoxelBound:d,volumeSourceOptions:e}).map(u=>({chunkSource:this.chunkManager.getChunkSource(oP,{credentialsProvider:this.credentialsProvider,spec:u,parameters:{baseUrl:this.baseUrl,collection:this.experimentInfo.collection,experiment:this.experimentInfo.key,channel:this.channel,resolution:s.key,encoding:this.encoding,window:this.window}}),chunkToMultiscaleTransform:c}))}))}getMeshSource(){return this.meshUrl!==void 0?this.chunkManager.getChunkSource(aP,{credentialsProvider:this.credentialsProvider,parameters:{baseUrl:this.meshUrl}}):null}}const mP=/^([^/?]+)\/([^/?]+)(?:\/([^/?]+))?(?:\?(.*))?$/;function OS(i,e,t,n,s){return i.memoize.getUncounted({hostname:e,collection:s,experiment:n,type:"boss:getExperimentInfo"},()=>js(t,`${e}/latest/collection/${s}/experiment/${n}/`,{},ke.cj).then(r=>fP(r,i,e,t,s,n)))}function vP(i,e,t,n,s,r){return i.memoize.getUncounted({hostname:e,collection:s,experiment:n,channel:r,type:"boss:getChannelInfo"},()=>js(t,`${e}/latest/collection/${s}/experiment/${n}/channel/${r}/`,{},ke.cj).then(pP))}function yP(i,e,t,n,s,r){return i.memoize.getUncounted({hostname:e,collection:n,experiment:s.key,channel:r,downsample:!0,type:"boss:getDownsampleInfoForChannel"},()=>js(t,`${e}/latest/downsample/${n}/${s.key}/${r}`,{},ke.cj)).then(o=>bP(o,s,r))}function SP(i,e){(0,f.Rf)(i);const t=(0,f.cQ)(i,"voxel_size",o=>(0,f.vS)(o,f.by)),n=(0,f.cQ)(i,"extent",o=>(0,f.vS)(o,f.gG)),s=(0,f.cQ)(i,"num_hierarchy_levels",f.bX),r=new Array;for(let o=0;o{const c=await OS(i,e,t,o,r),d=await yP(i,e,t,r,c,a),u=new gP(i,e,t,d,a,l),h=d.coordFrame,p={lowerBounds:h.voxelOffsetBase,upperBounds:Float64Array.from(h.imageSizeBase,(v,y)=>h.voxelOffsetBase[y]+v)},m=Oe({rank:3,names:h.names,units:["m","m","m"],scales:h.voxelSizeBaseInMeters,boundingBoxes:[En(p)]});return{modelTransform:wt(m),subsources:[{id:"default",default:!0,subsource:{volume:u}},{id:"bounds",default:!0,subsource:{staticAnnotations:xn(p)}}]}})}const _S=/^((?:http|https):\/\/[^/?]+)\/(.*)$/;function wP(i,e,t){return i.memoize.getUncounted({hostname:e,type:"boss:getCollections"},()=>js(t,`${e}/latest/collection/`,{},ke.cj).then(n=>(0,f.cQ)(n,"collections",s=>(0,f.$v)(s,f.zr))))}function xP(i,e,t,n){return i.memoize.getUncounted({hostname:e,collection:n,type:"boss:getExperiments"},()=>js(t,`${e}/latest/collection/${n}/experiment/`,{},ke.cj).then(s=>(0,f.cQ)(s,"experiments",r=>(0,f.$v)(r,f.zr))))}function EP(i,e,t,n){const s=n.coordFrameKey;return i.memoize.getUncounted({hostname:e,coordinateframe:s,experimentInfo:n,type:"boss:getCoordinateFrame"},()=>js(t,`${e}/latest/coord/${s}/`,{},ke.cj).then(r=>uP(r,n)))}function TP(i,e,t,n){const s=n.match(/^(?:([^/]+)(?:\/?([^/]*)(?:\/?([^/]*)(?:\/?([^/]*)?))?)?)?$/);if(s===null||s[1]===void 0)return Promise.reject(null);if(s[2]===void 0){const r=s[1]||"";return wP(i,e,t).then(o=>({offset:0,completions:Ht(r,o,a=>a+"/",()=>{})}))}if(s[3]===void 0){const r=s[2]||"";return xP(i,e,t,s[1]).then(o=>({offset:s[1].length+1,completions:Ht(r,o,a=>a+"/",()=>{})}))}return OS(i,e,t,s[2],s[1]).then(r=>{const o=Ht(s[3],r.channels,a=>a[0],a=>`${a[1].channelType} (${R[a[1].dataType]})`);return{offset:s[1].length+s[2].length+2,completions:o}})}function DP(i){const e=i.match(/^(?:https:\/\/[^.]+([^/]+))/);if(e===null)throw new Error(`Unable to construct auth server hostname from base hostname ${i}.`);return`https://auth${e[1]}/auth`}class IP extends Jt{constructor(e){super(),this.credentialsManager=e}get description(){return"bossDB: Block & Object Storage System"}getCredentialsProvider(e){const t=DP(e);return this.credentialsManager.getCredentialsProvider(AS,t)}get(e){const t=e.providerUrl.match(_S);if(t===null)throw new Error(`Invalid boss volume path: ${JSON.stringify(e.providerUrl)}`);const n=this.getCredentialsProvider(e.providerUrl);return CP(e.chunkManager,t[1],n,t[2])}async completeUrl(e){const t=e.providerUrl.match(_S);if(t===null)throw null;const n=t[1],s=this.getCredentialsProvider(t[1]),r=t[2],o=await TP(e.chunkManager,n,s,r);return yi(t[1].length+1,o)}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const VS=new Map;function Ot(i,e){VS.set(i,e)}function LP(i){const e=new xT(i.credentialsManager);for(const[t,n]of VS)try{e.register(t,n(i))}catch(s){console.warn(`Skipping ${t} data source: ${s}`)}return e}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("boss",i=>new IP(i.credentialsManager));/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class Nn extends T.O8{constructor(){super(...arguments),this.errorHandler=async(e,t)=>{const{status:n}=e;if(n===401||n===403&&!t.accessToken)return"refresh";throw e instanceof Error&&t.email!==void 0&&(e.message+=` (Using credentials for ${JSON.stringify(t.email)})`),e}}}function BS(i){let e,t,n;return(s,r)=>t!==void 0&&(e===void 0||s===void 0||e.generation!==s.generation)?(e===void 0&&n.addConsumer(r),t):(e=void 0,n=new Je.y3,t=i(s,n).then(o=>(e=o,n=void 0,o),o=>{throw n.isCanceled&&(n=void 0,t=void 0),o}),t)}function Xn(i){let e=0;return BS((t,n)=>i(n).then(s=>({generation:++e,credentials:s})))}class RP{constructor(){this.providers=new Map,this.topLevelManager=this}register(e,t){this.providers.set(e,t)}getCredentialsProvider(e,t){const n=this.providers.get(e);if(n===void 0)throw new Error(`No registered credentials provider: ${JSON.stringify(e)}`);return n(t,this.topLevelManager)}}class kP extends T.O8{constructor(e){super(),this.base=e,this.memoize=new rg.e}getCredentialsProvider(e,t){return this.memoize.get({key:e,parameters:t},()=>this.registerDisposer(this.base.getCredentialsProvider(e,t).addRef()))}}class PP extends kP{constructor(){super(new RP),this.base.topLevelManager=this}register(e,t){this.base.register(e,t)}}class AP extends Nn{constructor(e,t){super(),this.baseProvider=e,this.anonymousCredentials=t,this.anonymous=!0,this.get=BS(n=>this.anonymous&&n===void 0?Promise.resolve({generation:-10,credentials:this.anonymousCredentials}):(this.anonymous=!1,this.baseProvider.get(n)))}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Zn=new PP;/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class MP{constructor(){this.finished=new j.HN}}class NP{constructor(){this.oidcCallbackService="bossAuthCallback",this.pendingRequests=new Map,this.registerListener()}registerListener(){addEventListener("message",e=>{if(e.origin===location.origin)try{const t=(0,f.Rf)(JSON.parse(e.data));if((0,f.zr)(t.service)===this.oidcCallbackService){const s=(0,f.zr)(t.access_token),r=(0,f.zr)(t.state),o=this.pendingRequests.get(r);if(o===void 0)return;o.finished.dispatch(s)}}catch{}})}addPendingRequest(e){const t=new MP;return this.pendingRequests.set(e,t),t.finished.add(()=>{this.pendingRequests.delete(e)}),t}makeAuthRequestUrl(e){let t=`${e.authServer}/realms/BOSS/protocol/openid-connect/auth?`;return t+=`client_id=${encodeURIComponent(e.clientId)}`,t+=`&redirect_uri=${encodeURIComponent(e.redirect_uri)}`,t+="&response_mode=fragment",t+="&response_type=code%20id_token%20token",e.state&&(t+=`&state=${e.state}`),e.nonce&&(t+=`&nonce=${e.nonce}`),t}}let Iu;function OP(){return Iu===void 0&&(Iu=new NP),Iu}function _P(i,e=Je.fx){const t=Te(),n=Te(),s=OP(),r=s.makeAuthRequestUrl({state:t,clientId:i.clientId,redirect_uri:new URL(G(2974),G.b).href,authServer:i.authServer,nonce:n}),o=s.addPendingRequest(t),a=new Promise((l,c)=>{o.finished.add((d,u)=>{d!==void 0?l(d):c(u)})});if(o.finished.add(e.add(()=>{o.finished.dispatch(void 0,Je.wS)})),!e.isCanceled){const l=open(r);l!==null&&o.finished.add(()=>{l.close()})}return a}class VP extends Nn{constructor(e){super(),this.authServer=e,this.get=Xn(t=>{const n=new pe(!0);let s;return new Promise((r,o)=>{const a=()=>{s=void 0,n.dispose()};t.add(()=>{s!==void 0&&(s.cancel(),s=void 0,n.dispose(),o(Je.wS))});function l(u="Boss authorization required.",h="Request authorization."){n.setText(u+" ");const p=document.createElement("button");p.textContent=h,n.element.appendChild(p),p.addEventListener("click",()=>{d()}),n.setVisible(!0)}const c=this.authServer;function d(){s!==void 0&&s.cancel(),s=new Je.Qi,l("Waiting for Boss authorization...","Retry"),_P({realm:"boss",clientId:"endpoint",authServer:c},s).then(u=>{s!==void 0&&(a(),r(u))},u=>{s!==void 0&&(s=void 0,l(`Boss authorization failed: ${u}.`,"Retry"))})}l()})})}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Zn.register(AS,i=>new VP(i));/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Lu="google-brainmaps";function Ys(i,e,t,n=Je.fx){return(0,Js.Y)(e,`${i.serverUrl}${t.path}`,{method:t.method,body:t.payload},t.responseType==="json"?ke.cj:ke.Rc,n)}var jt=G(2020);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class BP extends it(lt()(Kn),jt.CR){}class FP extends it(lt()(Ra),jt.Ip){}class UP extends it(lt()(Qi),jt.Ve){}class $P extends it(lt()(Oa),jt.NV){}class GP extends it(lt()(ra),jt.Rw){}const qr=new Map;qr.set("UINT8",R.UINT8),qr.set("FLOAT",R.FLOAT32),qr.set("UINT32",R.UINT32),qr.set("UINT64",R.UINT64);function zP(i){(0,f.Rf)(i);try{return{corner:(0,f.cQ)(i,"corner",e=>(0,f.DW)(C.eR.create(),e,f.zo)),size:(0,f.cQ)(i,"size",e=>(0,f.DW)(C.eR.create(),e,f.Mo)),metadata:(0,f.cQ)(i,"metadata",f.z$)}}catch(e){throw new Error(`Failed to parse bounding box: ${e.message}`)}}class WP{constructor(e){try{(0,f.Rf)(e),this.numChannels=(0,f.cQ)(e,"channelCount",f.We),this.dataType=(0,f.cQ)(e,"channelType",t=>(0,f.j3)(t,qr)),this.voxelSize=(0,f.cQ)(e,"pixelSize",t=>(0,f.DW)(C.eR.create(),t,f.Mo)),this.upperVoxelBound=(0,f.cQ)(e,"volumeSize",t=>(0,f.DW)(C.eR.create(),t,f.We)),this.boundingBoxes=(0,f.cQ)(e,"boundingBox",t=>t===void 0?[]:(0,f.$v)(t,zP))}catch(t){throw new Error(`Failed to parse BrainMaps volume geometry: ${t.message}`)}}}function HP(i){return(0,f.Rf)(i),{name:(0,f.cQ)(i,"name",f.zr),type:(0,f.cQ)(i,"type",f.zr)}}function JP(i){try{return(0,f.Rf)(i),(0,f.cQ)(i,"meshes",e=>e===void 0?[]:(0,f.$v)(e,HP))}catch(e){throw new Error(`Failed to parse BrainMaps meshes specification: ${e.message}`)}}const jP="([0-9]*\\.?[0-9]+(?:[eE][-+]?[0-9]+)?)",Ru="([0-9]+)",FS=new RegExp(`^(.*)_${Ru}x${Ru}x${Ru}_lod([0-9]+)_${jP}$`);function YP(i,e){const t=new Map,n=i.scales[0],s=new Set;for(const o of e){if(o.type!=="TRIANGLES")continue;const a=o.name.match(FS);if(a===null)continue;const l=a[1];let c=t.get(l);c===void 0&&(c={key:l,chunkShape:C.eR.create(),lods:[]},t.set(l,c));const d=parseInt(a[5]);if(c.lods[d]!==void 0){s.add(l);continue}const u=C.eR.fromValues(parseInt(a[2],10),parseInt(a[3],10),parseInt(a[4],10)),h=new Uint32Array(3);for(let p=0;p<3;++p)h[p]=Math.ceil(n.upperVoxelBound[p]/u[p]);c.lods[d]={info:o,scale:parseFloat(a[6]),relativeBlockShape:u,gridShape:h}}const r=[];e:for(const o of t.values()){if(s.has(o.key))continue;const a=o.lods[0];if(a===void 0)continue;const l=a.relativeBlockShape;C.eR.multiply(o.chunkShape,l,n.voxelSize);for(let c=1;c{n.some(a=>a.name===o.name)||n.push(o)},r=new Set;for(const o of t){s({multi:o,single:void 0,name:o.key,partOfMultiscale:!1});for(const a of o.lods)r.add(a.info)}for(const o of e)s({single:o,multi:void 0,name:o.name,partOfMultiscale:r.has(o)});return n}class KP{constructor(e){try{(0,f.Rf)(e);const t=this.scales=(0,f.cQ)(e,"geometry",o=>(0,f.$v)(o,a=>new WP(a)));if(t.length===0)throw new Error("Expected at least one scale.");const n=t[0],s=this.numChannels=n.numChannels,r=this.dataType=n.dataType;for(let o=1,a=t.length;ol/1e9),o=[0,0,0],a=Array.from(t.upperVoxelBound);return e&&(n.push("c^"),s.push(""),r.push(1),o.push(0),a.push(this.numChannels)),Oe({names:n,units:s,scales:Float64Array.from(r),boundingBoxes:[En({lowerBounds:new Float64Array(n.length),upperBounds:Float64Array.from(a)})]})}}class qP extends ln{constructor(e,t,n,s,r,o,a){super(e),this.instance=t,this.credentialsProvider=n,this.volumeId=s,this.changeSpec=r,this.multiscaleVolumeInfo=o,this.encoding=a.encoding,this.jpegQuality=a.jpegQuality,this.chunkLayoutPreference=a.chunkLayoutPreference;let l=St.IMAGE;this.dataType===R.UINT64&&(l=St.SEGMENTATION),this.volumeType=l}get scales(){return this.multiscaleVolumeInfo.scales}get dataType(){return this.multiscaleVolumeInfo.dataType}get rank(){return this.multiscaleVolumeInfo.numChannels!==1?4:3}getSources(e){let t=jt.r7.RAW;(this.dataType===R.UINT64||this.dataType===R.UINT32)&&this.volumeType===St.SEGMENTATION&&this.encoding!==jt.r7.RAW?t=jt.r7.COMPRESSED_SEGMENTATION:this.volumeType===St.IMAGE&&this.dataType===R.UINT8&&this.multiscaleVolumeInfo.numChannels===1&&this.encoding!==jt.r7.RAW&&e.discreteValues!==!0&&(t=jt.r7.JPEG);const n=t===jt.r7.JPEG?this.jpegQuality:void 0,s=this.scales[0],{upperVoxelBound:r}=s,o=C.eR.create(),{rank:a}=this;return(0,F.RO)(this.scales.map((l,c)=>{C.eR.divide(o,l.voxelSize,s.voxelSize);let d=l.upperVoxelBound,u;const{numChannels:h}=l,p=new Float32Array((a+1)**2);p[(a+1)*a+a]=1;const m=new Float32Array(a);h!==1&&(d=Float32Array.of(...d,h),u=Uint32Array.of(1,1,1,h),p[(a+1)*3+3]=1,m[3]=h);for(let g=0;g<3;++g)p[(a+1)*g+g]=o[g],m[g]=r[g]/o[g];return qi({rank:a,minBlockSize:u,chunkToMultiscaleTransform:p,dataType:l.dataType,upperVoxelBound:d,volumeType:this.volumeType,volumeSourceOptions:e,chunkLayoutPreference:this.chunkLayoutPreference,maxCompressedSegmentationBlockSize:C.eR.fromValues(64,64,64)}).map(g=>({chunkSource:this.chunkManager.getChunkSource(BP,{credentialsProvider:this.credentialsProvider,spec:g,parameters:{volumeId:this.volumeId,changeSpec:this.changeSpec,scaleIndex:c,encoding:t,jpegQuality:n,instance:this.instance}}),chunkToMultiscaleTransform:p,upperClipBound:m}))}))}}function XP(i){const e=C.pB.create(),t=i.scales[0].voxelSize;for(let n=0;n<3;++n)e[5*n]=1/t[n];return e}function ZP(i){const e=i.match(/^([^:?/]+:[^:?/]+:[^:?/]+)(?::([^:?/]+))?(?:\/([^?]+))?(?:\?(.*))?$/);if(e===null)throw new Error(`Invalid Brain Maps volume key: ${JSON.stringify(i)}.`);let t;e[2]!==void 0&&(t={changeStackId:e[2]});const n=(0,f.bL)(e[4]||"");return{volumeId:e[1],changeSpec:t,meshName:e[3],parameters:n}}function e1(i){try{return(0,f.Rf)(i),{id:(0,f.cQ)(i,"id",f.zr),label:(0,f.cQ)(i,"label",f.zr),description:(0,f.cQ)(i,"description",f.z$)}}catch(e){throw new Error(`Failed to parse project: ${e.message}`)}}function US(i){try{return(0,f.Rf)(i),(0,f.cQ)(i,"project",e=>e===void 0?[]:(0,f.$v)(e,e1))}catch(e){throw new Error(`Error parsing project list: ${e.message}`)}}function $S(i,e){try{return(0,f.Rf)(i),(0,f.cQ)(i,e,t=>t===void 0?[]:(0,f.$v)(t,f.zr))}catch(t){throw new Error(`Error parsing dataset list: ${t.message}`)}}class a2{constructor(e,t){this.projects=new Map,this.hierarchicalVolumeIds=new Map;const{projects:n}=this;for(const s of US(e))n.set(s.id,s);try{verifyObject(t);const s=this.volumeIds=verifyObjectProperty(t,"volumeId",a=>a===void 0?[]:parseArray(a,verifyString));s.sort();const r=new Map;for(const a of s){let l=0;for(;;){let c=a.indexOf(":",l);c===-1?c=void 0:++c;const d=a.substring(0,l);let u=r.get(d);if(u===void 0&&(u=new Set,r.set(d,u)),u.add(a.substring(l,c)),c===void 0)break;l=c}}const{hierarchicalVolumeIds:o}=this;for(const[a,l]of r)o.set(a,Array.from(l))}catch(s){throw new Error(`Failed to parse Brain Maps volume list reply: ${s.message}`)}}}function t1(i){return(0,f.cQ)(i,"changeStackId",e=>e===void 0?void 0:(0,f.$v)(e,f.zr))}const n1=it(lt()(Rr),jt.rl);class i1 extends n1{constructor(e,t){super(e,{rank:3,relationships:["segments"],properties:[],...t}),this.credentialsProvider=this.registerDisposer(t.credentialsProvider.addRef())}hasNonSerializedProperties(){return!0}getSources(){const{upperVoxelBound:e}=this.parameters,t=Ko({rank:3,chunkDataSize:e,upperVoxelBound:e}),n=C.pB.create();return[[{chunkSource:this.chunkManager.getChunkSource(GP,{parent:this,spec:{limit:0,chunkToMultiscaleTransform:n,...t},parameters:this.parameters,credentialsProvider:this.credentialsProvider}),chunkToMultiscaleTransform:n}]]}}const s1=[{key:{value:"encoding",description:"Volume chunk data encoding"},values:[{value:"raw",description:""},{value:"jpeg",description:""},{value:"compressed_segmentation",description:""}]},{key:{value:"chunkLayout",description:"Volume chunk layout preference"},values:[{value:"isotropic",description:""},{value:"flat",description:""}]},{key:{value:"jpegQuality",description:"JPEG quality (1 to 100)"},values:[]}];class GS extends Jt{constructor(e,t){super(),this.instance=e,this.credentialsProvider=t}get description(){return this.instance.description}getMultiscaleInfo(e,t){return e.memoize.getUncounted({type:"brainmaps:getMultiscaleInfo",volumeId:t,instance:this.instance,credentialsProvider:xt(this.credentialsProvider)},()=>Ys(this.instance,this.credentialsProvider,{method:"GET",path:`/v1beta2/volumes/${t}`,responseType:"json"}).then(n=>new KP(n)))}getMeshesInfo(e,t){return e.memoize.getUncounted({type:"brainmaps:getMeshesInfo",volumeId:t,instance:this.instance,credentialsProvider:xt(this.credentialsProvider)},()=>Ys(this.instance,this.credentialsProvider,{method:"GET",path:`/v1beta2/objects/${t}/meshes`,responseType:"json"}).then(n=>JP(n)))}get(e){const{volumeId:t,changeSpec:n,meshName:s,parameters:r}=ZP(e.providerUrl);(0,f.Rf)(r);const o=(0,f.MM)(r,"encoding",d=>(0,f.sl)(d,jt.r7)),a=(0,f.MM)(r,"jpegQuality",d=>{const u=(0,f.bX)(d);if(u<1||u>100)throw new Error(`Expected integer in range [1, 100], but received: ${d}`);return u},70),l=(0,f.MM)(r,"chunkLayout",d=>(0,f.sl)(d,qf)),c={encoding:o,chunkLayoutPreference:l,jpegQuality:a};return e.chunkManager.memoize.getUncounted({type:"brainmaps:get",instance:this.instance,volumeId:t,changeSpec:n,brainmapsOptions:c},async()=>{const[d,u]=await Promise.all([this.getMultiscaleInfo(e.chunkManager,t),this.getMeshesInfo(e.chunkManager,t)]),h=new qP(e.chunkManager,this.instance,this.credentialsProvider,t,n,d,c),p={modelTransform:wt(d.getModelSpace(d.numChannels!==1)),subsources:[{id:s===void 0?"default":"volume",subsource:{volume:h},default:s===void 0}]},m=xn(d.box);d.scales[0].boundingBoxes.forEach((S,w)=>{m.add({type:Re.AXIS_ALIGNED_BOUNDING_BOX,description:S.metadata,pointA:S.corner,pointB:C.eR.add(C.eR.create(),S.corner,S.size),id:`boundingBox${w}`,properties:[]})}),p.subsources.push({id:"bounds",subsource:{staticAnnotations:m},default:!0});const v=QP(d,u),y=(S,w)=>{let b;const{single:x}=S;if(x!==void 0)x.type==="TRIANGLES"?b=e.chunkManager.getChunkSource(UP,{credentialsProvider:this.credentialsProvider,parameters:{instance:this.instance,volumeId:t,meshName:x.name,changeSpec:n}}):b=e.chunkManager.getChunkSource($P,{credentialsProvider:this.credentialsProvider,parameters:{instance:this.instance,volumeId:t,meshName:S.name,changeSpec:n}});else{const E=S.multi;b=e.chunkManager.getChunkSource(FP,{credentialsProvider:this.credentialsProvider,format:{fragmentRelativeVertices:!1,vertexPositionFormat:bn.Pc.float32},parameters:{instance:this.instance,volumeId:t,info:E,changeSpec:n}})}p.subsources.push({id:s===void 0?`/${S.name}`:"default",subsource:{mesh:b},subsourceToModelSubspaceTransform:XP(d),modelSubspaceDimensionIndices:[0,1,2],default:w})};if(s!==void 0){const S=v.find(w=>w.name===s);if(S===void 0)throw new Error(`Mesh/skeleton source not found: ${JSON.stringify(S)}`);y(S,!0)}else{let S=!0;for(const w of v)w.partOfMultiscale||(y(w,S),S=!1)}return n!==void 0&&p.subsources.push({id:"spatials",default:!0,modelSubspaceDimensionIndices:[0,1,2],subsource:{annotation:e.chunkManager.getChunkSource(i1,{parameters:{volumeId:t,changestack:n.changeStackId,instance:this.instance,upperVoxelBound:d.scales[0].upperVoxelBound},credentialsProvider:this.credentialsProvider})}}),p})}getProjectList(e){return e.memoize.getUncounted({instance:this.instance,type:"brainmaps:getProjectList"},()=>{const t=Ys(this.instance,this.credentialsProvider,{method:"GET",path:"/v1beta2/projects",responseType:"json"}).then(s=>US(s)),n=`${this.instance.description} project list`;return pe.forPromise(t,{delay:!0,initialMessage:`Retrieving ${n}.`,errorPrefix:`Error retrieving ${n}: `}),t})}getDatasetList(e,t){return e.memoize.getUncounted({instance:this.instance,type:`brainmaps:${t}:getDatasetList`},()=>{const n=Ys(this.instance,this.credentialsProvider,{method:"GET",path:`/v1beta2/datasets?project_id=${t}`,responseType:"json"}).then(r=>$S(r,"datasetIds")),s=`${this.instance.description} dataset list`;return pe.forPromise(n,{delay:!0,initialMessage:`Retrieving ${s}`,errorPrefix:`Error retrieving ${s}`}),n})}getVolumeList(e,t,n){return e.memoize.getUncounted({instance:this.instance,type:`brainmaps:${t}:${n}:getVolumeList`},()=>{const s=Ys(this.instance,this.credentialsProvider,{method:"GET",path:`/v1beta2/volumes?project_id=${t}&dataset_id=${n}`,responseType:"json"}).then(o=>{const a=$S(o,"volumeId"),l=t.length+n.length+2,c=[];for(const d of a)c.push(d.substring(l));return c}),r=`${this.instance.description} volume list`;return pe.forPromise(s,{delay:!0,initialMessage:`Retrieving ${r}`,errorPrefix:`Error retrieving ${r}`}),s})}getChangeStackList(e,t){return e.memoize.getUncounted({instance:this.instance,type:"brainmaps:getChangeStackList",volumeId:t},()=>{const n=Ys(this.instance,this.credentialsProvider,{method:"GET",path:`/v1beta2/changes/${t}/change_stacks`,responseType:"json"}).then(r=>t1(r)),s=`change stacks for ${t}`;return pe.forPromise(n,{delay:!0,initialMessage:`Retrieving ${s}.`,errorPrefix:`Error retrieving ${s}: `}),n})}async completeUrl(e){const{providerUrl:t}=e,n=t.match(/^([^:/?]*)(?::([^:/?]*)(?::([^:/?]*)(?::([^:/?]*))?(?:\/([^?]*))?(?:\?(.*))?)?)?$/);if(n===null)throw null;const[,s,r,o,a,l,c]=n;if(c!==void 0)return yi(t.length-c.length,await vg(c,s1));if(l!==void 0){const u=`${s}:${r}:${o}`,h=await this.getMeshesInfo(e.chunkManager,u),p=[],m=new Set;for(const g of h)if(g.name.startsWith(l))switch(g.type){case"LINE_SEGMENTS":p.push({value:g.name,description:"Skeletons"});break;case"TRIANGLES":{p.push({value:g.name,description:"Mesh (single-resolution)"});const v=g.name.match(FS);if(v!==null){const y=v[1];if(m.has(y))break;m.add(y),p.push({value:y,description:"Mesh (multi-resolution)"})}break}}return p.sort((g,v)=>(0,kr.e)(g.value,v.value)),{offset:t.length-l.length,completions:p}}if(a!==void 0){const u=`${s}:${r}:${o}`,h=await this.getChangeStackList(e.chunkManager,u);if(h===void 0)throw null;return{offset:t.length-a.length,completions:Hc(a,h)}}if(o!==void 0)return{offset:t.length-o.length,completions:Hc(o,await this.getVolumeList(e.chunkManager,s,r))};if(r!==void 0){const u=await this.getDatasetList(e.chunkManager,s);return{offset:t.length-r.length,completions:Hc(r,u.map(h=>`${h}:`))}}const d=await this.getProjectList(e.chunkManager);return{offset:0,completions:Ht(s,d,u=>`${u.id}:`,u=>u.label)}}}const r1={description:"Google Brain Maps",serverUrl:"https://brainmaps.googleapis.com"};/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */if(Ot("brainmaps",i=>new GS(r1,i.credentialsManager.getCredentialsProvider(Lu))),typeof NEUROGLANCER_BRAINMAPS_SERVERS<"u")for(const[i,e]of Object.entries(NEUROGLANCER_BRAINMAPS_SERVERS))Ot(`brainmaps-${i}`,t=>new GS(e,t.credentialsManager.getCredentialsProvider(Lu)));/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const o1="email",a1="openid",l1="https://accounts.google.com/o/oauth2/v2/auth";function c1(i){const e=i.split(".");try{if(e.length!==3)throw new Error("Invalid JWT format");const t=atob(e[1]),n=JSON.parse(t);return(0,f.Rf)(n),(0,f.cQ)(n,"email",f.zr)}catch(t){throw new Error(`Failed to decode id token: ${t.message}`)}}async function d1(i,e,t){const n=new T.O8;try{return await new Promise((s,r)=>{n.registerDisposer(t.add(()=>r(Je.wS))),n.registerEventListener(window,"message",o=>{if(o.origin===location.origin&&o.source===i)try{const a=(0,f.Rf)(o.data);if((0,f.cQ)(a,"state",f.zr)!==e)throw new Error("invalid state");const c=(0,f.cQ)(a,"id_token",f.zr),d={accessToken:(0,f.cQ)(a,"access_token",f.zr),tokenType:(0,f.cQ)(a,"token_type",f.zr),expiresIn:(0,f.cQ)(a,"expires_in",f.zr),scope:(0,f.cQ)(a,"scope",f.zr),email:c1(c)};s(d)}catch(a){r(new Error(`Received unexpected authentication response: ${a.message}`)),console.error("Response received: ",o.data)}})})}finally{n.dispose()}}function u1(i){let e=`${l1}?client_id=${encodeURIComponent(i.clientId)}`;const t=new URL(G(3956),G.b).href;e+=`&redirect_uri=${t}`;let n="token";const{scopes:s}=i;return s.includes("email")&&s.includes("openid")&&(n="token%20id_token"),e+=`&response_type=${n}`,e+="&include_granted_scopes=true",e+=`&scope=${encodeURIComponent(s.join(" "))}`,i.state&&(e+=`&state=${i.state}`),i.loginHint&&(e+=`&login_hint=${encodeURIComponent(i.loginHint)}`),i.immediate&&(e+="&immediate=true"),i.nonce!==void 0&&(e+=`&nonce=${i.nonce}`),i.authUser!==void 0&&(e+=`&authuser=${i.authUser}`),e}async function h1(i,e=Je.fx){const t=Te(),n=Te(),s=u1({state:t,nonce:n,clientId:i.clientId,scopes:i.scopes,approvalPrompt:i.approvalPrompt,loginHint:i.loginHint,immediate:i.immediate,authUser:i.authUser});let r,o;const a=[];if(i.immediate){const l=document.createElement("iframe");l.src=s,l.style.display="none",a.push(new Promise((c,d)=>{l.addEventListener("load",()=>{console.log("iframe loaded",l.contentDocument),l.contentDocument==null&&d(new Error("Immediate authentication failed"))})})),document.body.appendChild(l),r=l.contentWindow,o=()=>{at(l)}}else{const l=open(s);r=l,l!==null&&(o=()=>{try{l.close()}catch{}})}try{return await Promise.race([...a,d1(r,t,e)])}finally{o?.()}}class p1 extends Nn{constructor(e){super(),this.options=e,this.get=Xn(t=>{const{options:n}=this,s=new pe(!0);let r;return new Promise((o,a)=>{const l=()=>{r=void 0,s.dispose()};t.add(()=>{r!==void 0&&(r.cancel(),r=void 0,s.dispose(),a(Je.wS))});function c(u=`${n.description} authorization required.`,h="Request authorization."){s.setText(u+" ");const p=document.createElement("button");p.textContent=h,s.element.appendChild(p),p.addEventListener("click",()=>{d(!1)}),s.setVisible(!0)}function d(u){r!==void 0&&r.cancel(),r=new Je.Qi,c(`Waiting for ${n.description} authorization...`,"Retry"),h1({clientId:n.clientId,scopes:n.scopes,immediate:u,authUser:0},r).then(h=>{r!==void 0&&(l(),o(h))},h=>{r!==void 0&&(r=void 0,u?c():c(`${n.description} authorization failed: ${h}.`,"Retry"))})}d(!0)})})}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const f1="https://www.googleapis.com/auth/brainmaps";class g1 extends p1{constructor(e){super({clientId:e,scopes:[f1,a1,o1],description:"Brain Maps"})}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Zn.register(Lu,()=>new g1("639403125587-4k5hgdfumtrvur8v48e3pr7oo91d765k.apps.googleusercontent.com"));var zS=G(5990);/** + * @license + * This work is a derivative of the Google Neuroglancer project, + * Copyright 2016 Google Inc. + * The Derivative Work is covered by + * Copyright 2019 Howard Hughes Medical Institute + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const ku="DVID";class l2{constructor(e,t){this.baseUrl=e,this.nodeKey=t}getNodeApiUrl(e=""){return`${this.baseUrl}/api/node/${this.nodeKey}${e}`}getRepoInfoUrl(){return`${this.baseUrl}/api/repos/info`}getKeyValueUrl(e,t){return`${this.getNodeApiUrl()}/${e}/key/${t}`}getKeyValueRangeUrl(e,t,n){return`${this.getNodeApiUrl()}/${e}/keyrange/${t}/${n}`}getKeyValuesUrl(e){return`${this.getNodeApiUrl()}/${e}/keyvalues?jsontar=false`}}function c2(i,e){return i.includes("?")?i+="&":i+="?",i+="app=Neuroglancer",e&&(i+=`&u=${e}`),i}function qa(i){return i.text()}function d2(i,e=uncancelableToken){const t=`${i.url}`,n={method:i.method,body:i.payload};return i.responseType===""?cancellableFetchOk(t,n,qa,e):cancellableFetchOk(t,n,responseJson,e)}function m1(i,e,t=Je.fx){return v1(i,e.url,{method:e.method,body:e.payload},e.responseType===""?qa:e.responseType==="json"?ke.cj:ke.Rc,t)}function v1(i,e,t,n,s=Je.fx){return(0,Ka.R)(i,e,t,n,(r,o)=>{const a={...o};return r.token&&(a.headers={...a.headers,Authorization:`Bearer ${r}`}),a},r=>{const{status:o}=r;if(o===403||o===401)return"refresh";throw r},s)}var Vt=G(3819);/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */async function y1(i,e,t,n,s){const r=await(0,Js.Y)(i,`https://www.googleapis.com/storage/v1/b/${e}/o?delimiter=${encodeURIComponent(n)}&prefix=${encodeURIComponent(t)}&neuroglancerOrigin=${encodeURIComponent(location.origin)}`,{},ke.cj,s);(0,f.Rf)(r);const o=(0,f.MM)(r,"prefixes",f.si,[]),a=(0,f.MM)(r,"items",l=>(0,f.$v)(l,c=>((0,f.Rf)(c),(0,f.cQ)(c,"name",f.zr))),[]).filter(l=>!l.endsWith("_$folder$"));return[...o,...a]}async function S1(i,e,t,n,s){if(!n.startsWith("/"))throw null;const o=await y1(i,t,n.substring(1),"/",s),a=n.lastIndexOf("/");return{offset:a+e.length+1,completions:o.map(l=>({value:l.substring(a)}))}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */async function b1(i,e,t){const{text:n,contentType:s}=await Nt(t,i,{headers:{accept:"text/html"}},async l=>({text:await l.text(),contentType:l.headers.get("content-type")}),e);if(s===null||/\btext\/html\b/i.exec(s)===null)return[];const r=new DOMParser().parseFromString(n,"text/html"),o=r.evaluate("//a/@href",r,null,XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,null),a=[];for(let l=0,c=o.snapshotLength;lu.value,u=>u.description)};const{url:n,credentialsProvider:s}=wn(e,i),r=e.length-n.length;let o;try{o=(0,ke.Dl)(n)}catch{throw null}const{protocol:a,host:l,path:c}=o,d=await(async()=>{if(a==="gs+xml"&&c.length>0)return await Tu(s,`${a}://${l}`,`https://storage.googleapis.com/${l}`,c,t);if(a==="gs"&&c.length>0)return await S1(s,`${a}://${l}`,l,c,t);if(a==="s3"&&c.length>0)return await Vk(l,c,t);const u=n.match(/^((?:http|https):\/\/(?:storage\.googleapis\.com\/[^/]+|[^/]+\.storage\.googleapis\.com|[^/]+\.s3(?:[^./]+)?\.amazonaws.com))(\/.*)$/);if(u!==null)return await Tu(s,u[1],u[1],u[2],t);if((a==="http"||a==="https")&&c.length>0)return await C1(n,t,s);throw null})();return{offset:r+d.offset,completions:d.completions}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class x1 extends it(lt()(Kn),Vt.jj){}class E1 extends it(lt()(Qi),Vt.Ve){}class T1 extends it(lt()(Ra),Vt.Ip){}class D1 extends it(lt()(Oa),Vt.NV){get skeletonVertexCoordinatesInVoxels(){return!1}get vertexAttributes(){return this.parameters.metadata.vertexAttributes}}function On(i,e){const t=i.split("/");for(const n of e.split("/")){if(n===".."&&t.length!==0){t.length=t.length-1;continue}t.push(n)}return t.join("/")}class I1{constructor(e,t){(0,f.Rf)(e);const n=t===1?3:4,s=this.resolution=new Float64Array(n),r=this.voxelOffset=new Float32Array(n),o=this.size=new Float32Array(n);if(n===4&&(s[3]=1,o[3]=t),(0,f.cQ)(e,"resolution",l=>(0,f.Xu)(s.subarray(0,3),l,f.Mo)),(0,f.MM)(e,"voxel_offset",l=>(0,f.Xu)(r.subarray(0,3),l,f.bX)),(0,f.cQ)(e,"size",l=>(0,f.Xu)(o.subarray(0,3),l,f.We)),this.chunkSizes=(0,f.cQ)(e,"chunk_sizes",l=>(0,f.$v)(l,c=>{const d=new Uint32Array(n);return n===4&&(d[3]=t),(0,f.Xu)(d.subarray(0,3),c,f.We),d})),this.chunkSizes.length===0)throw new Error("No chunk sizes specified.");if(this.sharding=(0,f.cQ)(e,"sharding",Xa),this.sharding!==void 0&&this.chunkSizes.length!==1)throw new Error("Sharding requires a single chunk size per scale");(this.encoding=(0,f.cQ)(e,"encoding",l=>(0,f.sl)(l,Vt.r7)))===Vt.r7.COMPRESSED_SEGMENTATION&&(this.compressedSegmentationBlockSize=(0,f.cQ)(e,"compressed_segmentation_block_size",l=>(0,f.Xu)(C.eR.create(),l,f.We))),this.key=(0,f.cQ)(e,"key",f.zr),this.hidden=(0,f.cQ)(e,"hidden",f.uS)??!1}}function WS(i){(0,f.Rf)(i);const e=(0,f.cQ)(i,"data_type",y=>(0,f.sl)(y,R)),t=(0,f.cQ)(i,"num_channels",f.We),n=(0,f.cQ)(i,"type",y=>(0,f.sl)(y,St)),s=(0,f.cQ)(i,"mesh",f.z$),r=(0,f.cQ)(i,"skeletons",f.z$),o=(0,f.cQ)(i,"segment_properties",f.z$),a=(0,f.cQ)(i,"scales",y=>(0,f.$v)(y,S=>new I1(S,t)));if(a.length===0)throw new Error("Expected at least one scale");const l=a[0],c=t===1?3:4,d=new Float64Array(c),u=new Float64Array(c),h=new Float64Array(c),p=["x","y","z"],m=["m","m","m"];for(let y=0;y<3;++y)d[y]=l.resolution[y]/1e9,u[y]=l.voxelOffset[y],h[y]=u[y]+l.size[y];c===4&&(d[3]=1,h[3]=t,p[3]="c^",m[3]="");const v=Oe({rank:c,names:p,units:m,scales:d,boundingBoxes:[En({lowerBounds:u,upperBounds:h})]});return{dataType:e,volumeType:n,mesh:s,skeletons:r,segmentPropertyMap:o,scales:a,modelSpace:v}}class HS extends ln{constructor(e,t,n,s){super(e),this.credentialsProvider=t,this.url=n,this.info=s}get dataType(){return this.info.dataType}get volumeType(){return this.info.volumeType}get rank(){return this.info.modelSpace.rank}getSources(e){const t=this.info.scales[0].resolution,{rank:n}=this;return(0,F.RO)(this.info.scales.filter(s=>!s.hidden).filter(s=>s.key!=="placeholder").map(s=>{const{resolution:r}=s,o=n+1,a=new Float32Array(o*o);a[a.length-1]=1;const{lowerBounds:l,upperBounds:c}=this.info.modelSpace.boundingBoxes[0].box,d=new Float32Array(n),u=new Float32Array(n);for(let h=0;h<3;++h){const p=r[h]/t[h];a[o*h+h]=p;const m=s.voxelOffset[h];a[o*n+h]=m*p,d[h]=l[h]/p-m,u[h]=c[h]/p-m}return n===4&&(a[o*3+3]=1,d[3]=l[3],u[3]=c[3]),qi({rank:n,dataType:this.dataType,chunkToMultiscaleTransform:a,upperVoxelBound:s.size,volumeType:this.volumeType,chunkDataSizes:s.chunkSizes,baseVoxelOffset:s.voxelOffset,compressedSegmentationBlockSize:s.compressedSegmentationBlockSize,volumeSourceOptions:e}).map(h=>({chunkSource:this.chunkManager.getChunkSource(x1,{credentialsProvider:this.credentialsProvider,spec:h,parameters:{url:On(this.url,s.key),encoding:s.encoding,sharding:s.sharding}}),chunkToMultiscaleTransform:a,lowerClipBound:d,upperClipBound:u}))}))}}const L1=it(lt()(Rr),Vt.rl);class R1 extends it(lt()(ra),Vt.Rw){}class k1 extends L1{constructor(e,t){const{parameters:n}=t;super(e,{rank:n.rank,relationships:n.relationships.map(s=>s.name),properties:n.properties,parameters:n}),this.readonly=!0,this.metadata=t.metadata,this.credentialsProvider=t.credentialsProvider}getSources(){return[this.metadata.spatialIndices.map(e=>{const{spec:t}=e;return{chunkSource:this.chunkManager.getChunkSource(R1,{credentialsProvider:this.credentialsProvider,parent:this,spec:t,parameters:e.parameters}),chunkToMultiscaleTransform:t.chunkToMultiscaleTransform}})]}}function P1(i,e,t){return i.getChunkSource(E1,{parameters:t,credentialsProvider:e})}function JS(i){return(0,f.cQ)(i,"transform",e=>{const t=C.pB.create();return e!==void 0&&(0,f.Xu)(t.subarray(0,12),e,f.zo),C.pB.transpose(t,t),t})}function A1(i){(0,f.Rf)(i);const e=(0,f.cQ)(i,"@type",f.zr);let t;if(e==="neuroglancer_legacy_mesh")t=void 0;else{if(e!=="neuroglancer_multilod_draco")throw new Error(`Unsupported mesh type: ${JSON.stringify(e)}`);{const s=(0,f.cQ)(i,"lod_scale_multiplier",f.Mo),r=(0,f.cQ)(i,"vertex_quantization_bits",f.We),o=JS(i),a=(0,f.cQ)(i,"sharding",Xa);t={lodScaleMultiplier:s,transform:o,sharding:a,vertexQuantizationBits:r}}}const n=(0,f.cQ)(i,"segment_properties",f.z$);return{metadata:t,segmentPropertyMap:n}}async function M1(i,e,t){let n;try{n=await Qs(i,e,t)}catch(s){if((0,ke.El)(s))return{metadata:void 0};throw s}return A1(n)}function jS(i){return i===void 0?Vt.Y1.RAW:(0,f.sl)(i,Vt.Y1)}function Xa(i){if(i===void 0)return;(0,f.Rf)(i);const e=(0,f.cQ)(i,"@type",f.zr);if(e!=="neuroglancer_uint64_sharded_v1")throw new Error(`Unsupported sharding format: ${JSON.stringify(e)}`);const t=(0,f.cQ)(i,"hash",l=>(0,f.sl)(l,Vt.TV)),n=(0,f.cQ)(i,"preshift_bits",f.bX),s=(0,f.cQ)(i,"shard_bits",f.bX),r=(0,f.cQ)(i,"minishard_bits",f.bX),o=(0,f.cQ)(i,"minishard_index_encoding",jS),a=(0,f.cQ)(i,"data_encoding",jS);return{hash:t,preshiftBits:n,shardBits:s,minishardBits:r,minishardIndexEncoding:o,dataEncoding:a}}function N1(i){(0,f.Rf)(i);const e=(0,f.cQ)(i,"@type",f.zr);if(e!=="neuroglancer_skeletons")throw new Error(`Unsupported skeleton type: ${JSON.stringify(e)}`);const t=JS(i),n=new Map;(0,f.cQ)(i,"vertex_attributes",o=>{o!==void 0&&(0,f.$v)(o,a=>{(0,f.Rf)(a);const l=(0,f.cQ)(a,"id",f.zr);if(l==="")throw new Error("vertex attribute id must not be empty");if(n.has(l))throw new Error(`duplicate vertex attribute id ${JSON.stringify(l)}`);const c=(0,f.cQ)(a,"data_type",u=>(0,f.sl)(u,R)),d=(0,f.cQ)(a,"num_components",f.We);n.set(l,{dataType:c,numComponents:d})})});const s=(0,f.cQ)(i,"sharding",Xa),r=(0,f.cQ)(i,"segment_properties",f.z$);return{metadata:{transform:t,vertexAttributes:n,sharding:s},segmentPropertyMap:r}}async function O1(i,e,t){const n=await Qs(i,e,t);return N1(n)}function YS(){return Oe({names:["x","y","z"],units:["m","m","m"],scales:Float64Array.of(1e-9,1e-9,1e-9)})}async function QS(i,e,t){const{metadata:n,segmentPropertyMap:s}=await M1(i,e,t);if(n===void 0)return{source:P1(i,e,{url:t,lod:0}),transform:C.pB.create(),segmentPropertyMap:s};let r;const{vertexQuantizationBits:o}=n;if(o===10)r=bn.Pc.uint10;else if(o===16)r=bn.Pc.uint16;else throw new Error(`Invalid vertex quantization bits: ${o}`);return{source:i.getChunkSource(T1,{credentialsProvider:e,parameters:{url:t,metadata:n},format:{fragmentRelativeVertices:!0,vertexPositionFormat:r}}),transform:n.transform,segmentPropertyMap:s}}async function KS(i,e,t){const{metadata:n,segmentPropertyMap:s}=await O1(i,e,t);return{source:i.getChunkSource(D1,{credentialsProvider:e,parameters:{url:t,metadata:n}}),transform:n.transform,segmentPropertyMap:s}}function Qs(i,e,t){return i.memoize.getUncounted({type:"precomputed:metadata",url:t,credentialsProvider:xt(e)},async()=>await Nt(e,`${t}/info`,{},ke.cj))}function qS(i){const e=C.pB.create(),t=i.scales[0].resolution;for(let n=0;n<3;++n)e[5*n]=1/t[n];return e}async function _1(i,e,t,n){const s=WS(n),r=new HS(i.chunkManager,e,t,s),{modelSpace:o}=s,a=[{id:"default",default:!0,subsource:{volume:r}},{id:"bounds",default:!0,subsource:{staticAnnotations:xn(o.bounds)}}];if(s.segmentPropertyMap!==void 0){const l=On(t,s.segmentPropertyMap),c=await Qs(i.chunkManager,e,l),d=Xr(i.chunkManager,e,c,l);a.push({id:"properties",default:!0,subsource:{segmentPropertyMap:d}})}if(s.mesh!==void 0){const l=On(t,s.mesh),{source:c,transform:d}=await QS(i.chunkManager,e,l),u=qS(s);C.pB.multiply(u,u,d),a.push({id:"mesh",default:!0,subsource:{mesh:c},subsourceToModelSubspaceTransform:u})}if(s.skeletons!==void 0){const l=On(t,s.skeletons),{source:c,transform:d}=await KS(i.chunkManager,e,l),u=qS(s);C.pB.multiply(u,u,d),a.push({id:"skeletons",default:!0,subsource:{mesh:c},subsourceToModelSubspaceTransform:u})}return{modelTransform:wt(o),subsources:a}}async function V1(i,e,t){const{source:n,transform:s,segmentPropertyMap:r}=await KS(i.chunkManager,e,t),o=[{id:"default",default:!0,subsource:{mesh:n},subsourceToModelSubspaceTransform:s}];if(r!==void 0){const a=On(t,r),l=await Qs(i.chunkManager,e,a),c=Xr(i.chunkManager,e,l,a);o.push({id:"properties",default:!0,subsource:{segmentPropertyMap:c}})}return{modelTransform:wt(YS()),subsources:o}}function Pu(i,e){return(0,f.Rf)(e),{url:On(i,(0,f.cQ)(e,"key",f.zr)),sharding:(0,f.cQ)(e,"sharding",Xa)}}class B1{constructor(e,t){this.url=e,(0,f.Rf)(t);const n=(0,f.cQ)(t,"dimensions",uo),{rank:s}=n,r=(0,f.cQ)(t,"lower_bound",a=>(0,f.Xu)(new Float64Array(s),a,f.zo)),o=(0,f.cQ)(t,"upper_bound",a=>(0,f.Xu)(new Float64Array(s),a,f.zo));this.coordinateSpace=Oe({rank:s,names:n.names,units:n.units,scales:n.scales,boundingBoxes:[En({lowerBounds:r,upperBounds:o})]}),this.parameters={type:(0,f.cQ)(t,"annotation_type",a=>(0,f.sl)(a,Re)),rank:s,relationships:(0,f.cQ)(t,"relationships",a=>(0,f.$v)(a,l=>{const c=Pu(e,l),d=(0,f.cQ)(l,"id",f.zr);return{...c,name:d}})),properties:(0,f.cQ)(t,"properties",Dh),byId:(0,f.cQ)(t,"by_id",a=>Pu(e,a))},this.spatialIndices=(0,f.cQ)(t,"spatial",a=>(0,f.$v)(a,l=>{const c=Pu(e,l),d=(0,f.cQ)(l,"grid_shape",v=>(0,f.Xu)(new Float32Array(s),v,f.We)),u=(0,f.cQ)(l,"chunk_size",v=>(0,f.Xu)(new Float32Array(s),v,f.Mo)),h=(0,f.cQ)(l,"limit",f.We),p=new Float32Array(s);for(let v=0;v{r=(0,f.si)(r);const o=r.length,a=new Uint32Array(o*2);for(let l=0;l(0,f.$v)(r,o=>{(0,f.Rf)(o);const a=(0,f.cQ)(o,"id",f.zr),l=(0,f.MM)(o,"description",f.zr),c=(0,f.cQ)(o,"type",u=>{if(u!=="label"&&u!=="description"&&u!=="string"&&u!=="tags"&&u!=="number")throw new Error(`Invalid property type: ${JSON.stringify(u)}`);return u});if(c==="tags"){const u=(0,f.cQ)(o,"tags",f.si);let h=(0,f.MM)(o,"tag_descriptions",f.si);if(h===void 0)h=new Array(u.length),h.fill("");else if(h.length!==u.length)throw new Error(`Expected tag_descriptions to have length: ${u.length}`);const p=(0,f.cQ)(o,"values",m=>{if(!Array.isArray(m)||m.length!==n)throw new Error(`Expected ${n} values, but received: ${m.length}`);return m.map(g=>String.fromCharCode(...g))});return{id:a,description:l,type:c,tags:u,tagDescriptions:h,values:p}}if(c==="number"){const u=(0,f.cQ)(o,"data_type",g=>(0,f.sl)(g,R));if(u===R.UINT64)throw new Error("uint64 properties not supported");const h=(0,f.cQ)(o,"values",g=>{if(!Array.isArray(g)||g.length!==n)throw new Error(`Expected ${n} values, but received: ${g.length}`);return J[u].from(g)});let p=1/0,m=-1/0;for(let g=h.length-1;g>=0;--g){const v=h[g];vm&&(m=v)}return{id:a,description:l,type:c,dataType:u,values:h,bounds:[p,m]}}const d=(0,f.cQ)(o,"values",u=>{if((0,f.si)(u),u.length!==n)throw new Error(`Expected ${n} values, but received: ${u.length}`);return u});return{id:a,description:l,type:c,values:d}}));return lI({ids:t,properties:s})}const u2=it(lt()(nI),Vt.vq);function Xr(i,e,t,n){try{const s=(0,f.cQ)(t,"@type",f.zr);if(s!=="neuroglancer_segment_properties")throw new Error(`Unsupported segment property map type: ${JSON.stringify(s)}`);const r=(0,f.MM)(t,"inline",U1);return new rv({inlineProperties:r})}catch(s){throw new Error(`Error parsing segment property map: ${s.message}`)}}async function $1(i,e,t,n){return{modelTransform:wt(ki),subsources:[{id:"default",default:!0,subsource:{segmentPropertyMap:Xr(i.chunkManager,e,n,t)}}]}}const G1=/^([^#]*)(?:#(.*))?$/;function ns(i){let[,e,t]=i.match(G1);e.endsWith("/")&&(e=e.substring(0,e.length-1));const n=(0,f.bL)(t||"");return{url:e,parameters:n}}function Za(i,e){const t=(0,f.uz)(e);return t&&(i+=`#${t}`),i}class ZS extends Jt{get description(){return"Precomputed file-backed data source"}normalizeUrl(e){const{url:t,parameters:n}=ns(e.providerUrl);return e.providerProtocol+"://"+Za(t,n)}convertLegacyUrl(e){const{url:t,parameters:n}=ns(e.providerUrl);return e.type==="mesh"&&(n.type="mesh"),e.providerProtocol+"://"+Za(t,n)}get(e){const{url:t,parameters:n}=ns(e.providerUrl);return e.chunkManager.memoize.getUncounted({type:"precomputed:get",providerUrl:t,parameters:n},async()=>{const{url:s,credentialsProvider:r}=wn(t,e.credentialsManager);let o;try{o=await Qs(e.chunkManager,r,s)}catch(c){if((0,ke.El)(c)&&n.type==="mesh")return await XS(e,r,s);throw c}(0,f.Rf)(o);const a=(0,f.MM)(o,"redirect",f.zr);if(a!==void 0)throw new Jc(a);const l=(0,f.MM)(o,"@type",f.zr);switch(l){case"neuroglancer_skeletons":return await V1(e,r,s);case"neuroglancer_multilod_draco":case"neuroglancer_legacy_mesh":return await XS(e,r,s);case"neuroglancer_annotations_v1":return await F1(e,r,s,o);case"neuroglancer_segment_properties":return await $1(e,r,s,o);case"neuroglancer_multiscale_volume":case void 0:return await _1(e,r,s,o);default:throw new Error(`Invalid type: ${JSON.stringify(l)}`)}})}completeUrl(e){return ts(e.credentialsManager,e.providerUrl,e.cancellationToken)}}/** + * @license + * Copyright 2016 Google Inc., 2023 Gergely Csucs + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class z1 extends it(lt()(Kn),zS.D){}function W1(i){const{width:e,height:t,tilesize:n,overlap:s,format:r}=i,o=(0,f.sl)(r,zS.j),a=new Array;let l=e,c=t;for(;l>1||c>1;)a.push({width:l,height:c}),l=Math.ceil(l/2),c=Math.ceil(c/2);a.push({width:l,height:c});const d=3,u=Float64Array.of(1/1e9,1/1e9,1),h=new Float64Array(d),p=Float64Array.of(e,t,3),y=Oe({rank:d,names:["x","y","c^"],units:["m","m",""],scales:u,boundingBoxes:[En({lowerBounds:h,upperBounds:p})]});return{levels:a,modelSpace:y,overlap:s,tilesize:n,format:r,encoding:o}}class H1 extends ln{constructor(e,t,n,s){super(e),this.credentialsProvider=t,this.info=s,this.url=n.substring(0,n.lastIndexOf("."))+"_files"}get dataType(){return R.UINT8}get volumeType(){return St.IMAGE}get rank(){return this.info.modelSpace.rank}getSources(e){const{rank:t}=this,n=[Uint32Array.of(this.info.tilesize,this.info.tilesize,3)];return(0,F.RO)(this.info.levels.map((s,r,o)=>{const a=1<({chunkSource:this.chunkManager.getChunkSource(z1,{credentialsProvider:this.credentialsProvider,spec:h,parameters:{url:On(this.url,(o.length-1-r).toString()),encoding:this.info.encoding,format:this.info.format,overlap:this.info.overlap,tilesize:this.info.tilesize}}),chunkToMultiscaleTransform:c,upperClipBound:u}))}))}}function J1(i,e,t){if(t.endsWith(".json")||t.includes(".json?"))throw new Error("DZI-JSON: OpenSeadragon hack not supported yet.");return i.memoize.getUncounted({type:"deepzoom:metadata",url:t,credentialsProvider:xt(e)},async()=>{const n=await Nt(e,t,{},qa),r=new DOMParser().parseFromString(n,"text/xml").documentElement,o=(0,f.Rf)(r.getElementsByTagName("Size").item(0));return{width:(0,f.We)(o.getAttribute("Width")),height:(0,f.We)(o.getAttribute("Height")),tilesize:(0,f.We)((0,f.zr)(r.getAttribute("TileSize"))),overlap:(0,f.bX)((0,f.zr)(r.getAttribute("Overlap"))),format:(0,f.zr)(r.getAttribute("Format"))}})}async function j1(i,e,t,n){const s=W1(n),r=new H1(i.chunkManager,e,t,s),{modelSpace:o}=s,a=[{id:"default",default:!0,subsource:{volume:r}},{id:"bounds",default:!0,subsource:{staticAnnotations:xn(o.bounds)}}];return{modelTransform:wt(o),subsources:a}}class Y1 extends Jt{get description(){return"Deep Zoom file-backed data source"}normalizeUrl(e){const{url:t,parameters:n}=ns(e.providerUrl);return e.providerProtocol+"://"+Za(t,n)}convertLegacyUrl(e){const{url:t,parameters:n}=ns(e.providerUrl);return e.providerProtocol+"://"+Za(t,n)}get(e){const{url:t,parameters:n}=ns(e.providerUrl);return e.chunkManager.memoize.getUncounted({type:"deepzoom:get",providerUrl:t,parameters:n},async()=>{const{url:s,credentialsProvider:r}=wn(t,e.credentialsManager),o=await J1(e.chunkManager,r,s);return j1(e,r,s,o)})}completeUrl(e){return ts(e.credentialsManager,e.providerUrl,e.cancellationToken)}}/** + * @license + * Copyright 2017 Google Inc., 2023 Gergely Csucs + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("deepzoom",()=>new Y1);var Yt=G(8820);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const el=new Map;el.set("uint8",R.UINT8),el.set("uint32",R.UINT32),el.set("uint64",R.UINT64);class Q1{constructor(e){this.obj=e,(0,f.Rf)(e),(0,f.cQ)(e,"TypeName",f.zr)}get typeName(){return this.obj.TypeName}get compressionName(){return this.obj.Compression}}class K1{constructor(e,t,n){this.obj=e,this.name=t,this.base=n}}class q1 extends it(lt()(Kn),Yt.jj){}class X1 extends it(lt()(Oa),Yt.NV){}class Z1 extends it(lt()(Qi),Yt.Ve){}class tl extends K1{constructor(e,t,n,s,r){super(e,t,n),this.encoding=s;const o=(0,f.cQ)(e,"Extended",f.Rf),a=(0,f.cQ)(o,"Values",c=>(0,f.$v)(c,f.Rf));if(a.length<1)throw new Error("Expected Extended.Values property to have length >= 1, but received: ${JSON.stringify(extendedValues)}.");this.numLevels=1;const l=new Set(r);if(s===Yt.r7.COMPRESSED_SEGMENTATIONARRAY){const c=(0,f.cQ)(o,"MaxDownresLevel",f.We);this.numLevels=c+1}else for(;l.has(t+"_"+this.numLevels.toString());)this.numLevels+=1;l.has(t+"_meshes")?this.meshSrc=t+"_meshes":this.meshSrc="",l.has(t+"_skeletons")?this.skeletonSrc=t+"_skeletons":this.skeletonSrc="",this.dataType=(0,f.cQ)(a[0],"DataType",c=>(0,f.j3)(c,el)),this.voxelSize=(0,f.cQ)(o,"VoxelSize",c=>(0,f.Xu)(C.eR.create(),c,f.Mo)),this.blockSize=(0,f.cQ)(o,"BlockSize",c=>(0,f.Xu)(C.eR.create(),c,f.Mo)),this.lowerVoxelBound=(0,f.cQ)(o,"MinPoint",c=>(0,f.vp)(C.eR.create(),c)),this.upperVoxelBoundInclusive=(0,f.cQ)(o,"MaxPoint",c=>(0,f.vp)(C.eR.create(),c))}get volumeType(){return this.encoding===Yt.r7.COMPRESSED_SEGMENTATION||this.encoding===Yt.r7.COMPRESSED_SEGMENTATIONARRAY?St.SEGMENTATION:St.IMAGE}getSources(e,t,n,s){const{encoding:r}=this,o=[],a=64;for(let l=0;l0&&(p+="_"+l.toString());const m={baseUrl:t.baseUrl,nodeKey:t.nodeKey,dataInstanceKey:p,dataScale:l.toString(),encoding:r},g=C.pB.create();for(let y=0;y<3;++y)g[5*y]=c,g[12+y]=u[y]*c;const v=qi({rank:3,chunkToMultiscaleTransform:g,dataType:this.dataType,baseVoxelOffset:u,upperVoxelBound:C.eR.subtract(C.eR.create(),h,u),volumeType:this.volumeType,volumeSourceOptions:n,compressedSegmentationBlockSize:r===Yt.r7.COMPRESSED_SEGMENTATION||r===Yt.r7.COMPRESSED_SEGMENTATIONARRAY?C.eR.fromValues(8,8,8):void 0}).map(y=>({chunkSource:e.getChunkSource(q1,{spec:y,parameters:m,credentialsProvider:s}),chunkToMultiscaleTransform:g}));o.push(v)}return(0,F.RO)(o)}}function eA(i,e,t){(0,f.Rf)(i);const n=(0,f.cQ)(i,"Base",s=>new Q1(s));switch(n.typeName){case"uint8blk":case"grayscale8":{const s=n.compressionName.indexOf("jpeg")!==-1;return new tl(i,e,n,s?Yt.r7.JPEG:Yt.r7.RAW,t)}case"labels64":case"labelblk":return new tl(i,e,n,Yt.r7.COMPRESSED_SEGMENTATION,t);case"labelarray":case"labelmap":return new tl(i,e,n,Yt.r7.COMPRESSED_SEGMENTATIONARRAY,t);default:throw new Error(`DVID data type ${JSON.stringify(n.typeName)} is not supported.`)}}class nl{constructor(e){if(this.errors=[],this.dataInstances=new Map,this.vnodes=new Set,e instanceof nl){this.alias=e.alias,this.description=e.description,this.errors=e.errors,this.dataInstances=e.dataInstances;return}(0,f.Rf)(e),this.alias=(0,f.cQ)(e,"Alias",f.zr),this.description=(0,f.cQ)(e,"Description",f.zr);const t=(0,f.cQ)(e,"DataInstances",f.Rf),n=Object.keys(t);for(const o of n)try{this.dataInstances.set(o,eA(t[o],o,n))}catch(a){const l=`Failed to parse data instance ${JSON.stringify(o)}: ${a.message}`;console.log(l),this.errors.push(l)}const s=(0,f.cQ)(e,"DAG",f.Rf),r=(0,f.cQ)(s,"Nodes",f.Rf);for(const o of Object.keys(r))this.vnodes.add(o)}}function tA(i){try{const e=(0,f.vS)(i,n=>new nl(n)),t=new Map;for(const[n,s]of e){t.set(n,s);for(const r of s.vnodes)if(r!==n){const o=new nl(s);t.set(r,o)}}for(const[n,s]of t)s.uuid=n;return t}catch(e){throw new Error(`Failed to parse DVID repositories info: ${e.message}`)}}class nA{constructor(e){this.repositories=tA(e)}getNode(e){const t=[];for(const n of this.repositories.keys())n.startsWith(e)&&t.push(n);if(t.length!==1)throw new Error(`Node key ${JSON.stringify(e)} matches ${JSON.stringify(t)} nodes.`);return this.repositories.get(t[0])}}function e0(i,e,t){return i.memoize.getUncounted({type:"dvid:getServerInfo",baseUrl:e},()=>{const n=m1(t,{url:`${e}/api/repos/info`,method:"GET",responseType:"json"}).then(r=>new nA(r)),s=`repository info for DVID server ${e}`;return pe.forPromise(n,{initialMessage:`Retrieving ${s}.`,delay:!0,errorPrefix:`Error retrieving ${s}: `}),n})}class iA extends ln{constructor(e,t,n,s,r,o){super(e),this.baseUrl=t,this.nodeKey=n,this.dataInstanceKey=s,this.info=r,this.credentialsProvider=o}get dataType(){return this.info.dataType}get volumeType(){return this.info.volumeType}get rank(){return 3}getSources(e){return this.info.getSources(this.chunkManager,{baseUrl:this.baseUrl,nodeKey:this.nodeKey,dataInstanceKey:this.dataInstanceKey},e,this.credentialsProvider)}}const sA=/^((?:http|https):\/\/[^/]+)\/([^/]+)\/([^/]+)(\?.*)?$/;function t0(i){if(i.startsWith("https"))return i+"/api/server/token"}function rA(i){const e=i.match(sA);if(e===null)throw new Error(`Invalid DVID URL: ${JSON.stringify(i)}.`);const t={baseUrl:e[1],nodeKey:e[2],dataInstanceKey:e[3]},n=e[4];if(n&&n.length>1){const s=(0,f.bL)(n.substring(1));s.user&&(t.user=s.user)}return t.authServer=t0(t.baseUrl),t}function oA(i,e,t,n){const s=e.baseUrl,r=e.nodeKey,o=e.dataInstanceKey,a=t,l={lowerBounds:new Float64Array(a.lowerVoxelBound),upperBounds:Float64Array.from(a.upperVoxelBoundInclusive,h=>h+1)},c=Oe({rank:3,names:["x","y","z"],units:["m","m","m"],scales:Float64Array.from(a.voxelSize,h=>h/1e9),boundingBoxes:[En(l)]}),d=new iA(i.chunkManager,s,r,o,a,n),u={modelTransform:wt(c),subsources:[{id:"default",subsource:{volume:d},default:!0}]};if(a.meshSrc){const h=C.pB.create();for(let p=0;p<3;++p)h[5*p]=1/a.voxelSize[p];u.subsources.push({id:"meshes",default:!0,subsource:{mesh:i.chunkManager.getChunkSource(Z1,{parameters:{...e,dataInstanceKey:a.meshSrc},credentialsProvider:n})},subsourceToModelSubspaceTransform:h})}return a.skeletonSrc&&u.subsources.push({id:"skeletons",default:!0,subsource:{mesh:i.chunkManager.getChunkSource(X1,{parameters:{...e,dataInstanceKey:a.skeletonSrc},credentialsProvider:n})}}),u.subsources.push({id:"bounds",subsource:{staticAnnotations:xn(l)},default:!0}),u}function aA(i){const e=rA(i.providerUrl),{baseUrl:t,nodeKey:n,dataInstanceKey:s}=e;return i.chunkManager.memoize.getUncounted({type:"dvid:MultiscaleVolumeChunkSource",baseUrl:t,nodeKey:n,dataInstanceKey:s},async()=>{const r=i.credentialsManager.getCredentialsProvider(ku,{dvidServer:e.baseUrl,authServer:e.authServer}),a=(await e0(i.chunkManager,t,r)).getNode(n);if(a===void 0)throw new Error(`Invalid node: ${JSON.stringify(n)}.`);const l=a.dataInstances.get(s);if(!(l instanceof tl))throw new Error(`Invalid data instance ${s}.`);return oA(i,e,l,r)})}function lA(i,e){return{offset:0,completions:Ht(e,i.dataInstances.values(),t=>t.name,t=>`${t.base.typeName}`)}}function cA(i,e){const t=e.match(/^(?:([^/]+)(?:\/([^/]*))?)?$/);if(t===null)throw new Error("Invalid DVID URL syntax.");if(t[2]===void 0)return{offset:0,completions:Ht(e,i.repositories.values(),r=>r.uuid+"/",r=>`${r.alias}: ${r.description}`)};const n=t[1],s=i.getNode(n);return yi(n.length+1,lA(s,t[2]))}async function dA(i){const e=/^((?:http|https):\/\/[^/]+)\/([^?]*).*$/,n=i.providerUrl.match(e);if(n===null)throw null;const s=n[1],r=n[2],o=t0(s),a=await e0(i.chunkManager,s,i.credentialsManager.getCredentialsProvider(ku,{dvidServer:s,authServer:o}));return yi(s.length+1,cA(a,r))}class uA extends Jt{constructor(e){super(),this.credentialsManager=e}get description(){return"DVID"}get(e){return aA(e)}completeUrl(e){return dA(e)}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("dvid",i=>new uA(i.credentialsManager));/** + * @license + * This work is a derivative of the Google Neuroglancer project, + * Copyright 2016 Google Inc. + * The Derivative Work is covered by + * Copyright 2019 Howard Hughes Medical Institute + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */async function hA(i,e=Je.fx){return{token:await(0,ke.Bk)(i,{method:"GET",credentials:"include"},qa,e)}}class pA extends Nn{constructor(e){super(),this.authServer=e,this.get=Xn(t=>{if(!this.authServer)return Promise.resolve({token:""});const n=new pe(!0);let s;return new Promise((r,o)=>{const a=()=>{s=void 0,n.dispose()};t.add(()=>{s!==void 0&&(s.cancel(),s=void 0,n.dispose(),o(Je.wS))});function l(d,u="DVID authorization required.",h="Request authorization."){n.setText(u+" ");const p=document.createElement("button");p.textContent=h,n.element.appendChild(p),p.addEventListener("click",()=>{const m=d.match(/^[^/]+\/\/[^/.]+\.([^/]+)/);if(m){const g=`https://flyemlogin.${m[1]}/login`;window.alert(`Please log into ${g} and then refresh the neurogalncer page to try again. +If you are unable to log into ${g}, please check your authorization server ${d} to make sure it is correct.`)}else window.alert(`Please check your authorization server ${d} to make sure it is correct.`)}),n.setVisible(!0)}function c(d){s!==void 0&&s.cancel(),s=new Je.Qi,l(d,"Waiting for DVID authorization...","Retry"),hA(d,s).then(u=>{s!==void 0&&(a(),r(u))},u=>{s!==void 0&&(s=void 0,l(d,`DVID authorization failed: ${u}.`,"Retry"))})}c(this.authServer)})})}}class fA extends AP{constructor(e,t){super(new pA(t),{})}}/** + * @license + * This work is a derivative of the Google Neuroglancer project, + * Copyright 2016 Google Inc. + * The Derivative Work is covered by + * Copyright 2019 Howard Hughes Medical Institute + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Zn.register(ku,i=>new fA(i.dvidServer,i.authServer));/** + * @license + * Copyright 2019 The Neuroglancer Authors + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Zr=1,gA="GrapheneMeshSource:NewSegment";var mA=(i=>(i[i.RAW=0]="RAW",i[i.JPEG=1]="JPEG",i[i.COMPRESSED_SEGMENTATION=2]="COMPRESSED_SEGMENTATION",i))(mA||{});class vA{}vA.RPC_ID="graphene/VolumeChunkSource";class n0{}n0.RPC_ID="graphene/ChunkedGraphSource";class i0{}i0.RPC_ID="graphene/MeshSource";class h2{}const eo=async i=>i;function s0(i,e){const t=P.R.rshift(new P.R,i,64-e);return P.R.equal(t,P.R.ONE)}function yA(i){if(i.charAt(0)==="~"){const t=i.substring(1).split(/:(.+)/);return{key:t[0],fragmentId:t[1]}}return{key:i,fragmentId:i}}const SA="ChunkedGraphLayer",bA="ChunkedGraphLayer:updateSources",p2=5;function CA(i){const{rank:e,dataType:t}=i,{baseVoxelOffset:n=new Float32Array(e)}=i;return{...Ko(i),baseVoxelOffset:n,dataType:t}}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Au(i){return new Date(i.getTime()-i.getTimezoneOffset()*6e4).toISOString().slice(0,-8)}class wA extends T.O8{constructor(e,t,n){super(),this.model=e,this.element=document.createElement("input"),this.registerDisposer(e.changed.add(()=>this.updateView()));const{element:s}=this;s.type="datetime-local",t&&this.setMin(t),n&&this.setMax(n),this.registerEventListener(s,"change",()=>this.updateModel()),this.updateView()}setMin(e){const{element:t}=this;t.min=Au(e)}setMax(e){const{element:t}=this;t.max=Au(e)}disposed(){at(this.element)}updateView(){this.model.value?this.element.value=Au(new Date(this.model.value)):this.element.value=""}updateModel(){try{this.element.value?this.model.restoreState(new Date(this.element.value).valueOf()):this.model.restoreState(0)}catch{}this.updateView()}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function il(i,e=0){const t=C.ln.clone([...i]);return t[3]=e,t}const sl=C.eR.fromValues(1,0,0),Mu=C.eR.fromValues(0,0,1),xA=il(sl,.5),EA=il(Mu,.5),TA=il(sl,.25),DA=il(Mu,.25),IA=C.ln.fromValues(.5,.5,.5,.01),LA=new P.R(Ie(xA)),RA=new P.R(Ie(EA)),kA=new P.R(Ie(IA)),PA=C.ln.fromValues(0,0,0,.5),AA=C.eR.fromValues(1,1,1);class MA extends it(lt()(Qi),i0){getFragmentKey(e,t){return yA(t)}}class NA{constructor(e,t){const n=/^(https?:\/\/[.\w:\-/]+)\/segmentation\/(?:1\.0|table)\/([^/]+)\/?$/,s=e.match(n);if(s===null)throw Error(`Graph URL invalid: ${e}`);this.table=s[2];const{table:r}=this;this.segmentationUrl=`${s[1]}/segmentation/api/v${Zr}/table/${r}`,this.meshingUrl=`${s[1]}/meshing/api/v${Zr}/table/${r}`,this.l2CacheUrl=`${s[1]}/l2cache/api/v${Zr}`;try{(0,f.Rf)(t),this.supported_api_versions=(0,f.cQ)(t,"supported_api_versions",o=>(0,f.$v)(o,f.B8))}catch{this.supported_api_versions=[0]}if(!(Zr in this.supported_api_versions)){const o=`This Neuroglancer branch requires Graph Server version ${Zr}, but the server only supports version(s) ${this.supported_api_versions}.`;throw new Error(o)}}}const OA=8;class _A{constructor(e){(0,f.Rf)(e),this.chunkSize=(0,f.cQ)(e,"chunk_size",t=>(0,f.Xu)(C.eR.create(),t,f.We)),this.nBitsForLayerId=(0,f.MM)(e,"n_bits_for_layer_id",f.We,OA)}}function VA(i,e,t){const n=WS(i),s=(0,f.cQ)(i,"data_dir",a=>wn(a,t)).url,r=(0,f.cQ)(i,"app",a=>new NA(e,a)),o=(0,f.cQ)(i,"graph",a=>new _A(a));return{...n,app:r,graph:o,dataUrl:s}}class BA extends HS{constructor(e,t,n){super(e,void 0,n.dataUrl,n),this.chunkedGraphCredentialsProvider=t,this.info=n}getChunkedGraphSource(){const{rank:e}=this,t=this.info.scales[0],n=CA({rank:e,dataType:this.info.dataType,upperVoxelBound:t.size,chunkDataSize:Uint32Array.from(this.info.graph.chunkSize),baseVoxelOffset:t.voxelOffset}),s=e+1,r=new Float32Array(s*s);r[r.length-1]=1;const{lowerBounds:o,upperBounds:a}=this.info.modelSpace.boundingBoxes[0].box,l=new Float32Array(e),c=new Float32Array(e);for(let d=0;d<3;++d)r[s*d+d]=1,r[s*e+d]=t.voxelOffset[d],l[d]=o[d],c[d]=a[d];return{chunkSource:this.chunkManager.getChunkSource(tM,{spec:n,credentialsProvider:this.chunkedGraphCredentialsProvider,parameters:{url:`${this.info.app.segmentationUrl}/node`}}),chunkToMultiscaleTransform:r,lowerClipBound:l,upperClipBound:c}}}function r0(i){return(0,f.cQ)(i,"transform",e=>{const t=C.pB.create();return e!==void 0&&(0,f.Xu)(t.subarray(0,12),e,f.zo),C.pB.transpose(t,t),t})}function FA(i){(0,f.Rf)(i);const e=(0,f.cQ)(i,"@type",f.zr);let t;if(e==="neuroglancer_legacy_mesh"){const s=(0,f.cQ)(i,"sharding",a0);s===void 0?t=void 0:t={lodScaleMultiplier:0,transform:r0(i),sharding:s,vertexQuantizationBits:10}}else{if(e!=="neuroglancer_multilod_draco")throw new Error(`Unsupported mesh type: ${JSON.stringify(e)}`);{const s=(0,f.cQ)(i,"lod_scale_multiplier",f.Mo),r=(0,f.cQ)(i,"vertex_quantization_bits",f.We),o=r0(i),a=(0,f.cQ)(i,"sharding",a0);t={lodScaleMultiplier:s,transform:o,sharding:a,vertexQuantizationBits:r}}}const n=(0,f.cQ)(i,"segment_properties",f.z$);return{metadata:t,segmentPropertyMap:n}}async function UA(i,e,t){let n;try{n=await Nu(i,e,t)}catch(s){if((0,ke.El)(s))return{metadata:void 0};throw s}return FA(n)}function o0(i){return i===void 0?Vt.Y1.RAW:(0,f.sl)(i,Vt.Y1)}function $A(i){if(i===void 0)return;(0,f.Rf)(i);const e=(0,f.cQ)(i,"@type",f.zr);if(e!=="neuroglancer_uint64_sharded_v1")throw new Error(`Unsupported sharding format: ${JSON.stringify(e)}`);const t=(0,f.cQ)(i,"hash",l=>(0,f.sl)(l,Vt.TV)),n=(0,f.cQ)(i,"preshift_bits",f.bX),s=(0,f.cQ)(i,"shard_bits",f.bX),r=(0,f.cQ)(i,"minishard_bits",f.bX),o=(0,f.cQ)(i,"minishard_index_encoding",o0),a=(0,f.cQ)(i,"data_encoding",o0);return{hash:t,preshiftBits:n,shardBits:s,minishardBits:r,minishardIndexEncoding:o,dataEncoding:a}}function a0(i){if(i===void 0)return;(0,f.Rf)(i);const e=new Array;for(const t in i){const n=Number(t);e[n]=$A(i[n])}return e}function GA(i,e,t){return i.getChunkSource(MA,{parameters:e,credentialsProvider:t})}async function zA(i,e,t,n,s){const{metadata:r,segmentPropertyMap:o}=await UA(i,void 0,n),a={manifestUrl:t,fragmentUrl:n,lod:0,sharding:r?.sharding,nBitsForLayerId:s},l=r?.transform||C.pB.create();return{source:GA(i,a,e),transform:l,segmentPropertyMap:o}}function Nu(i,e,t){return i.memoize.getUncounted({type:"graphene:metadata",url:t,credentialsProvider:xt(e)},async()=>await Nt(e,`${t}/info`,{},ke.cj))}function WA(i){const e=C.pB.create(),t=i.scales[0].resolution;for(let n=0;n<3;++n)e[5*n]=1/t[n];return e}async function HA(i,e,t,n){const s=VA(n,t,i.credentialsManager),r=new BA(i.chunkManager,e,s),o=new QA;i.state&&o.restoreState(i.state);const a=new ll(s,e,r,o),{modelSpace:l}=s,c=[{id:"default",default:!0,subsource:{volume:r}},{id:"graph",default:!0,subsource:{segmentationGraph:a}},{id:"bounds",default:!0,subsource:{staticAnnotations:xn(l.bounds)}}];if(s.segmentPropertyMap!==void 0){const d=On(t,s.segmentPropertyMap),u=await Nu(i.chunkManager,e,d),h=Xr(i.chunkManager,e,u,d);c.push({id:"properties",default:!0,subsource:{segmentPropertyMap:h}})}if(s.mesh!==void 0){const{source:d,transform:u}=await zA(i.chunkManager,e,s.app.meshingUrl,On(s.dataUrl,s.mesh),s.graph.nBitsForLayerId),h=WA(s);C.pB.multiply(h,h,u),c.push({id:"mesh",default:!0,subsource:{mesh:d},subsourceToModelSubspaceTransform:h})}return{modelTransform:wt(l),subsources:c,state:o}}class JA extends ZS{get description(){return"Graphene file-backed data source"}get(e){const{url:t,parameters:n}=ns(e.providerUrl);return e.chunkManager.memoize.getUncounted({type:"graphene:get",providerUrl:t,parameters:n},async()=>{const{url:s,credentialsProvider:r}=wn(t,e.credentialsManager);let o;try{o=await Nu(e.chunkManager,r,s)}catch(c){throw(0,ke.El)(c)&&n.type==="mesh"&&console.log("does this happen?"),c}(0,f.Rf)(o);const a=(0,f.MM)(o,"redirect",f.zr);if(a!==void 0)throw new Jc(a);const l=(0,f.MM)(o,"@type",f.zr);switch(l){case"neuroglancer_multiscale_volume":case void 0:return await HA(e,r,s,o);default:throw new Error(`Invalid type: ${JSON.stringify(l)}`)}})}}function to(i){for(const e of i.dataSources){const{loadState:t}=e;if(!(t===void 0||t.error!==void 0)){for(const n of t.subsources)if(n.enabled&&n.subsourceEntry.id==="graph")return n}}}function rl(i,e,t,n){const{subsourceEntry:s}=e,r=new Ih(e.loadedDataSource.transform,new _.B0([]),["associated segments"]),o=new Yf;o.color.value.set(n),o.relationshipStates.set("associated segments",{segmentationState:new _.B0(i.displayState),showMatches:new nt(!1)});const a=new jo({localPosition:i.localPosition,transform:e.getRenderLayerTransform(),source:r,displayState:o,dataSource:e.loadedDataSource.layerDataSource,subsourceIndex:e.subsourceIndex,subsourceId:s.id,subsubsourceId:t,role:li.ANNOTATION});return i.addAnnotationLayerState(a,e),a}function jA(i,e){return(0,f.MM)(i,e,t=>P.R.parseString(String(t)))}function l0(i,e){return(0,f.cQ)(i,e,t=>P.R.parseString(String(t)))}function no(i){const e=l0(i,d0),t=l0(i,u0),n=(0,f.cQ)(i,h0,s=>(0,f.f4)(s));return{segmentId:e,rootId:t,position:n}}const Ks=i=>({[d0]:i.segmentId.toJSON(),[u0]:i.rootId.toJSON(),[h0]:[...i.position]}),c0="id",d0="segmentId",u0="rootId",h0="position",p0="sink",ol="source",f0="timestamp",g0="multicut",m0="focusSegment",v0="sinks",y0="sources",S0="merge",b0="merges",C0="autosubmit",YA="locked",w0="mergedRoot",x0="error",E0="findPath",T0="target",D0="centroids",I0="precision";class QA extends T.O8{constructor(){super(),this.changed=new j.IY,this.timestamp=new _.DN(0,e=>e),this.multicutState=new XA,this.mergeState=new KA,this.findPathState=new qA,this.registerDisposer(this.timestamp.changed.add(()=>{this.multicutState.reset(),this.changed.dispatch()})),this.registerDisposer(this.multicutState.changed.add(()=>{this.changed.dispatch()})),this.registerDisposer(this.mergeState.changed.add(()=>{this.changed.dispatch()})),this.registerDisposer(this.findPathState.changed.add(()=>{this.changed.dispatch()}))}replaceSegments(e,t){this.multicutState.replaceSegments(e,t),this.mergeState.replaceSegments(e,t),this.findPathState.replaceSegments(e,t)}reset(){this.timestamp.reset(),this.multicutState.reset(),this.mergeState.reset(),this.findPathState.reset()}toJSON(){return{[f0]:this.timestamp.toJSON(),[g0]:this.multicutState.toJSON(),[S0]:this.mergeState.toJSON(),[E0]:this.findPathState.toJSON()}}restoreState(e){(0,f.MM)(e,f0,t=>{this.timestamp.restoreState(t)}),(0,f.MM)(e,g0,t=>{this.multicutState.restoreState(t)}),(0,f.MM)(e,S0,t=>{this.mergeState.restoreState(t)}),(0,f.MM)(e,E0,t=>{this.findPathState.restoreState(t)})}}class KA extends T.O8{constructor(){super(),this.changed=new j.IY,this.merges=new _.B0([]),this.autoSubmit=new nt(!1),this.registerDisposer(this.merges.changed.add(this.changed.dispatch))}replaceSegments(e,t){const{merges:{value:n}}=this,s=t.size===1?[...t][0]:void 0;for(const r of n){if(r.source&&e.has(r.source.rootId))if(s)r.source.rootId=s;else{this.reset();return}if(r.sink&&e.has(r.sink.rootId))if(s)r.sink.rootId=s;else{this.reset();return}}}reset(){this.merges.value=[],this.autoSubmit.reset()}toJSON(){const{merges:e,autoSubmit:t}=this,n=s=>{const r={[c0]:s.id,[YA]:s.locked,[p0]:Ks(s.sink),[ol]:Ks(s.source)};return s.mergedRoot&&(r[w0]=s.mergedRoot.toJSON()),s.error&&(r[x0]=s.error),r};return{[b0]:e.value.filter(s=>s.source).map(n),[C0]:t.toJSON()}}restoreState(e){function t(s){const r=jA(s,w0),o=(0,f.cQ)(s,c0,f.zr),a=(0,f.MM)(s,x0,f.zr),l=!1,c=no(s[p0]),d=no(s[ol]);return{id:o,locked:l,sink:c,source:d,mergedRoot:r,error:a}}const n=s=>(0,f.$v)(s,r=>t(r));this.merges.value=(0,f.cQ)(e,b0,n),this.autoSubmit.restoreState((0,f.MM)(e,C0,f.aO))}}class qA extends T.O8{constructor(){super(),this.changed=new j.IY,this.triggerPathUpdate=new j.IY,this.source=new _.DN(void 0,e=>e),this.target=new _.DN(void 0,e=>e),this.centroids=new _.DN([],e=>e),this.precisionMode=new nt(!0),this.registerDisposer(this.source.changed.add(()=>{this.centroids.reset(),this.changed.dispatch()})),this.registerDisposer(this.target.changed.add(()=>{this.centroids.reset(),this.changed.dispatch()})),this.registerDisposer(this.centroids.changed.add(this.changed.dispatch))}get path(){const e=[],{source:{value:t},target:{value:n},centroids:{value:s}}=this;if(!t||!n||s.length===0)return e;for(let a=0;a{this.source.restoreState(no(t))}),(0,f.MM)(e,T0,t=>{this.target.restoreState(no(t))}),(0,f.MM)(e,D0,t=>{this.centroids.restoreState(t)}),(0,f.MM)(e,I0,t=>{this.precisionMode.restoreState(t)})}}class XA extends T.O8{constructor(e=new _.DN(void 0,n=>n),t=new _.B0(!1)){super(),this.focusSegment=e,this.blueGroup=t,this.changed=new j.IY,this.sinks=new _._Y,this.sources=new _._Y;const n=()=>{this.sinks.size===0&&this.sources.size===0&&(this.focusSegment.value=void 0)};this.registerDisposer(e.changed.add(this.changed.dispatch)),this.registerDisposer(this.sinks.changed.add(n)),this.registerDisposer(this.sources.changed.add(n)),this.registerDisposer(this.blueGroup.changed.add(this.changed.dispatch)),this.registerDisposer(this.sinks.changed.add(this.changed.dispatch)),this.registerDisposer(this.sources.changed.add(this.changed.dispatch))}replaceSegments(e,t){const n=t.size===1?[...t][0]:void 0,{focusSegment:{value:s}}=this;if(s&&e.has(s))if(n){this.focusSegment.value=n;for(const r of this.sinks)r.rootId=n;for(const r of this.sources)r.rootId=n;this.changed.dispatch()}else this.reset()}reset(){this.focusSegment.reset(),this.blueGroup.value=!1,this.sinks.clear(),this.sources.clear()}toJSON(){const{focusSegment:e,sinks:t,sources:n}=this;return{[m0]:e.toJSON(),[v0]:[...t].map(Ks),[y0]:[...n].map(Ks)}}restoreState(e){const t=r=>(0,f.$v)(r,o=>no(o));(0,f.MM)(e,m0,r=>{this.focusSegment.restoreState(P.R.parseString(String(r)))});const n=(0,f.cQ)(e,v0,t),s=(0,f.cQ)(e,y0,t);for(const r of n)this.sinks.add(r);for(const r of s)this.sources.add(r)}swapGroup(){this.blueGroup.value=!this.blueGroup.value}get activeGroup(){return this.blueGroup.value?this.sources:this.sinks}get segments(){return[...this.redSegments,...this.blueSegments]}get redSegments(){return[...this.sinks].filter(e=>!P.R.equal(e.segmentId,e.rootId)).map(e=>e.segmentId)}get blueSegments(){return[...this.sources].filter(e=>!P.R.equal(e.segmentId,e.rootId)).map(e=>e.segmentId)}}class is extends _d{constructor(e,t,n,s){super(e,t.displayState.segmentationGroupState.value),this.graph=e,this.layer=t,this.chunkSource=n,this.state=s,this.annotationLayerStates=[],this.operationIds=[],this.lastDeselectionMessageExists=!1,this.deleteMergeSubmission=m=>{const{mergeAnnotationState:g}=this;m.locked=!1,g.source.delete(g.source.getReference(m.id))},this.submitMerge=async(m,g=1)=>{const y=to(this.layer).loadedDataSource.transform.inputSpace.value.scales.map(S=>S/1e-9);m.error=void 0;for(let S=1;S<=g;S++)try{const w=await this.graph.graphServer.mergeSegments(qs(m.sink,y),qs(m.source,y)),{mergeRoot:b,operationId:x}=w;pe.showTemporaryMessage(`Operation ID ${x}`,3e3),this.operationIds.push(x);const E=new qn;E.add(m.sink.rootId),E.add(m.source.rootId);const D=new qn;return D.add(b),this.state.replaceSegments(E,D),b}catch(w){if(S===g)throw m.error=w.message||"unknown",w}return P.R.ZERO};const r=t.displayState.segmentationGroupState.value;this.previousVisibleSegmentCount=r.visibleSegments.size,this.registerDisposer(r.selectedSegments.changed.add((m,g)=>{m!==null&&(m=Array().concat(m)),this.selectedSegmentsChanged(m,g)})),this.registerDisposer(r.visibleSegments.changed.add((m,g)=>{m!==null&&(m=Array().concat(m)),this.visibleSegmentsChanged(m,g)}));const{annotationLayerStates:o,state:{multicutState:a,findPathState:l}}=this;this.registerDisposer(s.timestamp.changed.add(()=>{r.selectedSegments.clear(),r.temporaryVisibleSegments.clear()}));const c=to(t),d=rl(t,c,"sinks",sl),u=rl(t,c,"sources",Mu);R0(a.sinks,d),R0(a.sources,u),o.push(d,u),t.tool.value instanceof io&&(t.tool.value=void 0),this.mergeAnnotationState=rl(t,c,"grapheneMerge",sl);{const{mergeState:m}=s,{merges:g,autoSubmit:v}=m,{mergeAnnotationState:y}=this,{visibleSegments:S}=r;for(const w of g.value)y.source.add(dM(w));this.registerDisposer(y.source.childAdded.add(w=>{const b=w;b.relatedSegments[0].map(D=>S.has(D))[0]===!1?(setTimeout(()=>{const{tool:D}=t;D.value instanceof io&&D.value.deactivate()},0),pe.showTemporaryMessage("Cannot merge a hidden segment.")):g.value.length{const{tool:D}=t;D.value instanceof io&&D.value.deactivate()},0),pe.showTemporaryMessage(`Maximum of ${M0} simultanous merges allowed.`))})),this.registerDisposer(y.source.childCommitted.add(w=>{const b=y.source.getReference(w),x=b.value;if(x){const E=x.relatedSegments[0],D=E.map(L=>S.has(L));E.length<4&&(y.source.delete(b),pe.showTemporaryMessage("Cannot merge segment with itself.")),D[2]===!1&&(y.source.delete(b),pe.showTemporaryMessage("Cannot merge a hidden segment."));const I=g.value.find(L=>L.id===b.id);if(I&&!I?.locked){const L=A0(x,!1);I.sink=L.sink,I.source=L.source,g.changed.dispatch(),v.value&&this.bulkMerge([I])}}b.dispose()})),this.registerDisposer(y.source.childDeleted.add(w=>{let b=!1;const x=g.value.filter(E=>{const D=E.id!==w||E.locked;return D||(b=!0),D});b&&(g.value=x)}))}const h=rl(t,c,"findpath",AA);this.findPathAnnotationState=h,h.source.childDeleted.add(m=>{l.source.value?.annotationReference?.id===m&&(l.source.value=void 0),l.target.value?.annotationReference?.id===m&&(l.target.value=void 0)});const p=()=>{const{path:m,source:g,target:v}=l,y=h.source;g.value&&!g.value.annotationReference&&cl(y,g.value,"find path source"),v.value&&!v.value.annotationReference&&cl(y,v.value,"find path target");for(const S of y)S.id!==g.value?.annotationReference?.id&&S.id!==v.value?.annotationReference?.id&&y.delete(y.getReference(S.id));for(const S of m)y.add(S)};this.registerDisposer(l.changed.add(p)),this.registerDisposer(l.triggerPathUpdate.add(()=>{const g=to(this.layer).loadedDataSource.transform.inputSpace.value.scales.map(v=>v/1e-9);this.submitFindPath(l.precisionMode.value,g).then(v=>{})})),p()}createRenderLayers(e,t,n){return[new nM(e,this.chunkSource.getChunkedGraphSource(),t,n,this.graph.info.graph.nBitsForLayerId)]}visibleSegmentsChanged(e,t){const{segmentsState:n}=this,{focusSegment:{value:s}}=this.graph.state.multicutState;if(s&&!n.visibleSegments.has(s)&&(n.selectedSegments.has(s)?pe.showTemporaryMessage("Can't hide active multicut segment.",3e3):pe.showTemporaryMessage("Can't deselect active multicut segment.",3e3),n.selectedSegments.add(s),n.visibleSegments.add(s),e&&(e=e.filter(r=>!P.R.equal(r,s)))),e===null){this.segmentsState.segmentEquivalences.clear(),pe.showTemporaryMessage(`Hid all ${this.previousVisibleSegmentCount} segment(s).`,3e3);return}for(const r of e)if(!t&&!s0(r,this.graph.info.graph.nBitsForLayerId)){const o=[...n.segmentEquivalences.setElements(r)].length;n.segmentEquivalences.deleteSet(r),this.lastDeselectionMessage&&this.lastDeselectionMessageExists&&(this.lastDeselectionMessage.dispose(),this.lastDeselectionMessageExists=!1),this.lastDeselectionMessage=pe.showMessage(`Hid ${o} segment(s).`),this.lastDeselectionMessageExists=!0,setTimeout(()=>{this.lastDeselectionMessageExists&&(this.lastDeselectionMessage.dispose(),this.lastDeselectionMessageExists=!1)},2e3)}this.previousVisibleSegmentCount=n.visibleSegments.size}selectedSegmentsChanged(e,t){const{segmentsState:n}=this;if(e===null){const s=this.segmentsState.selectedSegments.size;pe.showTemporaryMessage(`Deselected all ${s} segment(s).`,3e3);return}for(const s of e){const r=s0(s,this.graph.info.graph.nBitsForLayerId),o=s.clone();t&&r&&this.graph.getRoot(o).then(a=>{n.visibleSegments.has(o)&&n.visibleSegments.add(a),n.selectedSegments.delete(o),n.selectedSegments.add(a)})}}computeSplit(e,t){}getMeshSource(){const{layer:e}=this;for(const t of e.dataSources){const{loadState:n}=t;if(n instanceof Yc){const{subsources:s}=n.dataSource,r=s.filter(a=>a.id==="graph")[0];if(r&&r.subsource.segmentationGraph&&r.subsource.segmentationGraph!==this.graph)continue;const o=s.filter(a=>a.id==="mesh")[0];if(o)return o.subsource.mesh}}}meshAddNewSegments(e){const t=this.getMeshSource();if(t)for(const n of e)t.rpc.invoke(gA,{rpcId:t.rpcId,segment:n.toString()})}async submitMulticut(e){const{state:{multicutState:t}}=this,{sinks:n,sources:s}=t;if(n.size===0||s.size===0)return pe.showTemporaryMessage("Must select both red and blue groups to perform a multi-cut.",7e3),!1;{const r=await this.graph.graphServer.splitSegments([...n].map(l=>qs(l,e)),[...s].map(l=>qs(l,e))),{splitRoots:o,operationId:a}=r;if(o.length===0)return pe.showTemporaryMessage("No split found.",3e3),!1;{console.log("Operation ID:",a),pe.showTemporaryMessage(`Operation ID ${a}`,3e3),this.operationIds.push(a);const l=t.focusSegment.value;t.reset();const{segmentsState:c}=this;c.selectedSegments.delete(l);for(const h of[...n,...s])c.selectedSegments.delete(h.rootId);this.meshAddNewSegments(o),c.selectedSegments.add(o),c.visibleSegments.add(o);const d=new qn;d.add(l);const u=new qn;return u.add(o),this.state.replaceSegments(d,u),!0}}}async bulkMerge(e){const{merges:t}=this.state.mergeState,n=d=>new Promise(u=>{if(d.length===0){u([]);return}const h=[];let p=0,m=0;const g=(v,y)=>{if(p===d.length||y.length===0)return;m++;let S=[];const w=()=>{b++,b===y.length&&(m-=1),m===0&&u(h)};let b=0;for(const x of y){x.locked=!0,x.status="trying...",t.changed.dispatch();const E=[x.source.rootId,x.sink.rootId];this.submitMerge(x,3).then(D=>{h.push(...E),x.status="done",x.mergedRoot=D,t.changed.dispatch(),p+=1,g(p,S),S=[],w(),cM(5e3).then(()=>{this.deleteMergeSubmission(x)})}).catch(()=>{t.changed.dispatch(),S.push(x),p>v&&(g(p,S),S=[]),w()})}};g(p,d)});e=e.filter(d=>!d.locked&&d.source);const s=await n(e),r=[];for(const d of e){d.error?(d.locked=!1,d.status=d.error):d.mergedRoot&&r.push(d.mergedRoot);const u=await this.graph.graphServer.filterLatestRoots(r),h=this.layer.displayState.segmentationGroupState.value,{visibleSegments:p,selectedSegments:m}=h;m.delete(s),this.meshAddNewSegments(u),m.add(u),p.add(u),t.changed.dispatch()}const o=this.layer.displayState.segmentationGroupState.value,{visibleSegments:a,selectedSegments:l}=o;l.delete(s);const c=await this.graph.graphServer.filterLatestRoots(r);l.add(c),a.add(c),t.changed.dispatch()}async submitFindPath(e,t){const{state:{findPathState:n}}=this,{source:s,target:r}=n;if(!s.value||!r.value)return!1;const o=await this.graph.findPath(s.value,r.value,e,t);return pe.showTemporaryMessage("Path found!",5e3),n.centroids.value=o,!0}}async function L0(i){if(i.response){let e;return i.response.headers.get("content-type")==="application/json"?e=(await i.response.json()).message:e=await i.response.text(),e}}async function al(i,e){let t,n=()=>{};e.initialMessage&&(t=new pe(!0),t.setText(e.initialMessage),n=t.dispose.bind(t));try{const s=await i;return n(),s}catch(s){if(s instanceof ke.j$&&s.response){const{errorPrefix:r=""}=e,o=await L0(s)||"unknown error";throw t||(t=new pe(!0)),t.setErrorMessage(r+o),t.setVisible(!0),new Error(`[${s.response.status}] ${r}${o}`)}throw s}}const qs=(i,e)=>{const{rootId:t,segmentId:n,position:s}=i;return{rootId:t,segmentId:n,position:s.map((r,o)=>r*e[o])}},Ou=Symbol("Graph Server Not Specified.");class ZA{constructor(e,t){this.url=e,this.credentialsProvider=t}async getTimestampLimit(){const e=await Nt(this.credentialsProvider,`${this.url}/oldest_timestamp`,{},ke.cj),t=(0,f.cQ)(e,"iso",f.zr);return new Date(t).valueOf()}async getRoot(e,t=0){const n=t/1e3,s=`${this.url}/node/${String(e)}/root?int64_as_str=1${t>0?`×tamp=${n}`:""}`,r=Nt(this.credentialsProvider,s,{},eo),a=await(await al(r,{initialMessage:`Retrieving root for segment ${e}`,errorPrefix:"Could not fetch root: "})).json();return P.R.parseString(a.root_id)}async mergeSegments(e,t){const{url:n}=this;if(n==="")return Promise.reject(Ou);const s=Nt(this.credentialsProvider,`${n}/merge?int64_as_str=1`,{method:"POST",body:JSON.stringify([[String(e.segmentId),...e.position],[String(t.segmentId),...t.position]])},eo);try{const o=await(await s).json(),a=P.R.parseString(o.new_root_ids[0]),l=P.R.parseString(o.operation_id);return{mergeRoot:a,operationId:l}}catch(r){if(r instanceof ke.j$){const o=await L0(r);throw new Error(o)}throw r}}async splitSegments(e,t){const{url:n}=this;if(n==="")return Promise.reject(Ou);const s=Nt(this.credentialsProvider,`${n}/split?int64_as_str=1`,{method:"POST",body:JSON.stringify({sources:e.map(c=>[String(c.segmentId),...c.position]),sinks:t.map(c=>[String(c.segmentId),...c.position])})},eo),o=await(await al(s,{initialMessage:`Splitting ${e.length} sources from ${t.length} sinks`,errorPrefix:"Split failed: "})).json(),a=new Array(o.new_root_ids.length);for(let c=0;ca.toJSON())})},eo),r=await(await al(n,{errorPrefix:"Could not check latest: "})).json(),o=[];for(const[a,l]of r.is_latest.entries())l&&o.push(e[a]);return o}async findPath(e,t,n){const{url:s}=this;if(s==="")return Promise.reject(Ou);const r=Nt(this.credentialsProvider,`${s}/graph/find_path?int64_as_str=1&precision_mode=${Number(n)}`,{method:"POST",body:JSON.stringify([[String(e.rootId),...e.position],[String(t.rootId),...t.position]])},eo),a=await(await al(r,{initialMessage:`Finding path between ${e.segmentId} and ${t.segmentId}`,errorPrefix:"Path finding failed: "})).json(),c=(0,f.cQ)(a,"centroids_list",p=>(0,f.$v)(p,f.pf)),u=a["failed_l2_ids"];u&&u.length>0&&pe.showTemporaryMessage("Some level 2 meshes are missing, so the path shown may have a poor level of detail.");const h=(0,f.MM)(a,"l2_path",f.si);return{centroids:c,l2_path:h}}}class ll extends Od{constructor(e,t,n,s){super(),this.info=e,this.credentialsProvider=t,this.chunkSource=n,this.state=s,this.connections=new Set,this.l2CacheAvailable=void 0,this.timestampLimit=new _.DN(0,r=>r),this.graphServer=new ZA(e.app.segmentationUrl,t),this.graphServer.getTimestampLimit().then(r=>{this.timestampLimit.value=r})}connect(e){const t=new is(this,e,this.chunkSource,this.state);return this.connections.add(t),t.registerDisposer(()=>{this.connections.delete(t)}),t}get visibleSegmentEquivalencePolicy(){return Rt.y6.MAX_REPRESENTATIVE|Rt.y6.NONREPRESENTATIVE_EXCLUDED}async isL2CacheUrlAvailable(){if(this.l2CacheAvailable!==void 0)return this.l2CacheAvailable;try{const{l2CacheUrl:e,table:t}=this.info.app,n=await Nt(void 0,`${e}/table_mapping`,{},ke.cj);return this.l2CacheAvailable=!!(n&&n[t]),this.l2CacheAvailable}catch(e){return console.error("e",e),!1}}getRoot(e){return this.graphServer.getRoot(e,this.state.timestamp.value)}async findPath(e,t,n,s){const{l2CacheUrl:r,table:o}=this.info.app,a=n&&await this.isL2CacheUrlAvailable();let{centroids:l,l2_path:c}=await this.graphServer.findPath(qs(e,s),qs(t,s),n&&!a);if(n&&a&&c){const u=`${r}/table/${o}/attributes`;try{const h=await Nt(this.credentialsProvider,u,{method:"POST",body:JSON.stringify({l2_ids:c})},ke.cj);l=c.map(p=>(0,f.MM)(h,p,m=>(0,f.VH)(m.rep_coord_nm))).filter(p=>p!==void 0)}catch(h){console.log("e",h)}}return l.map(u=>u.map((h,p)=>h/s[p]))}tabContents(e,t,n){const s=document.createElement("div");s.style.display="contents";const r=document.createElement("div");r.className="neuroglancer-segmentation-toolbox",s.appendChild(fa(n,e,n.visibility,k0)),r.appendChild(Wn(t,e.toolBinder,{toolJson:_u,label:"Multicut",title:"Multicut segments"})),r.appendChild(Wn(t,e.toolBinder,{toolJson:Vu,label:"Merge",title:"Merge segments"})),r.appendChild(Wn(t,e.toolBinder,{toolJson:Bu,label:"Find Path",title:"Find Path"})),s.appendChild(r),s.appendChild(t.registerDisposer(new iM(e,e.annotationDisplayState)).element);const o=n.element;return o.classList.add("neuroglancer-annotations-tab"),o.classList.add("neuroglancer-graphene-tab"),s}async merge(e,t){return new P.R}async split(e,t){return{include:e,exclude:t}}trackSegment(e,t){return()=>{console.log("trackSegment... do nothing",e,t)}}}class eM extends Lr{constructor(e,t){super(e,t)}}class tM extends it(lt()(eM),n0){}class nM extends Fi{constructor(e,t,n,s,r){super(),this.chunkManager=e,this.source=t,this.displayState=n,this.localPosition=s,this.layerChunkProgressInfo=new fo,this.leafRequestsActive=this.registerDisposer(ft.make(e.rpc,!0)),this.chunkTransform=this.registerDisposer((0,_.ol)(a=>bo(()=>po(sc(a))),this.displayState.transform));const o=this.sharedObject=this.backend=this.registerDisposer(new Ia(e,n,this.layerChunkProgressInfo));o.RPC_TYPE_ID=SA,o.initializeCounterpartWithChunkManager({source:t.chunkSource.addCounterpartRef(),localPosition:this.registerDisposer(ft.makeFromExisting(e.rpc,this.localPosition)).rpcId,leafRequestsActive:this.leafRequestsActive.rpcId,nBitsForLayerId:this.registerDisposer(ft.make(e.rpc,r)).rpcId}),this.registerDisposer(o.visibility.add(this.visibility)),this.registerDisposer(this.leafRequestsActive.changed.add(()=>{this.showOrHideMessage(this.leafRequestsActive.value)}))}attach(e){super.attach(e);const t=this.chunkTransform.value,n=e.view.displayDimensionRenderInfo.value;e.state={chunkTransform:t,displayDimensionRenderInfo:n},e.state.source=e.registerDisposer((0,_.no)((s,r,o)=>{const a=sa(o,r,l=>[[this.source]],e.messages,this);return e.view.flushBackendProjectionParameters(),this.sharedObject.rpc.invoke(bA,{layer:this.sharedObject.rpcId,view:e.view.rpcId,displayDimensionRenderInfo:o,sources:ta(a)}),a[0][0]},this.displayState.transform,e.view.displayDimensionRenderInfo))}isReady(){return!0}showOrHideMessage(e){this.leafRequestsStatusMessage&&e?(this.leafRequestsStatusMessage.dispose(),this.leafRequestsStatusMessage=void 0,pe.showTemporaryMessage("Loading chunked graph segmentation...",3e3)):!this.leafRequestsStatusMessage&&!e&&(this.leafRequestsStatusMessage=pe.showMessage("At this zoom level, chunked graph segmentation will not be loaded. Please zoom in if you wish to load it."))}}const _u="grapheneMulticutSegments",Vu="grapheneMergeSegments",Bu="grapheneFindPath";class iM extends hy{constructor(e,t){super(e,t),this.layer=e,this.displayState=t;const{graphConnection:{value:n}}=e;if(n instanceof is)for(const s of n.annotationLayerStates)this.annotationStates.add(s)}get annotationStates(){return this._annotationStates===void 0&&(this._annotationStates=this.registerDisposer(new ly)),this._annotationStates}}const cl=(i,e,t)=>{const n={id:"",point:e.position,type:Re.POINT,properties:[],relatedSegments:[[e.segmentId,e.rootId]],description:t},s=i.add(n);e.annotationReference=s},R0=(i,e)=>{const t=e.source;t.childDeleted.add(n=>{const s=[...i].find(r=>r.annotationReference?.id===n);s&&i.delete(s)}),i.changed.add((n,s)=>{if(n===null){for(const r of t)t.delete(t.getReference(r.id));return}s?cl(t,n):n.annotationReference&&t.delete(n.annotationReference)});for(const n of i)cl(t,n)};function sM(i,e){const n=to(e).getRenderLayerTransform(),s=bo(()=>po(sc(n.value)));if(s.error!==void 0)return;const r=new Float32Array(s.modelTransform.unpaddedRank);if(gs(r,i,e.localPosition.value,s.layerRank,s.combinedGlobalLocalToChunkTransform))return r}const rM=(i,e)=>{if(e.updateUnconditionally())return sM(e.unsnappedPosition,i)},k0={label:"Time",title:"View segmentation at earlier point of time",toolJson:"grapheneTime",...oM()};gd(Ct,k0);function oM(){return{makeControl:(i,e)=>{const t=i.displayState.segmentationGroupState.value,{graph:{value:n}}=t,s=n instanceof ll?n.state.timestamp:new _.DN(0,c=>c),r=n instanceof ll?n.timestampLimit:new _.DN(0,c=>c),o=document.createElement("div");o.classList.add("neuroglancer-time-control");const a=new _.DN(s.value,c=>c);a.changed.add(()=>{a.value!==s.value&&n instanceof ll&&(!(t.selectedSegments.size+t.temporaryVisibleSegments.size>0)||confirm("Changing graphene time will clear all selected segments.")?s.value=a.value:a.value=s.value)});const l=e.registerDisposer(new wA(a,new Date(r.value),new Date));return r.changed.add(()=>{l.setMin(new Date(r.value))}),s.changed.add(()=>{s.value!==a.value&&(a.value=s.value)}),o.appendChild(l.element),{controlElement:o,control:l}},activateTool:i=>{}}}const P0=(i,e)=>i.value!==0?(pe.showTemporaryMessage("Editing can not be performed with a segmentation at an older state."),e.cancel(),!0):!1,aM=Ae.fromObject({"at:shift?+control+mousedown0":{action:"set-anchor"},"at:shift?+keyg":{action:"swap-group"},"at:shift?+enter":{action:"submit"}});class lM extends gi{toJSON(){return _u}activate(e){const{layer:t}=this,{graphConnection:{value:n}}=t;if(!n||!(n instanceof is)){e.cancel();return}const{state:{multicutState:s,timestamp:r},segmentsState:o}=n;if(P0(r,e)||(e.registerDisposer(r.changed.add(()=>{e.cancel()})),s===void 0))return;const{body:a,header:l}=Vi(e);l.textContent="Multicut segments",a.classList.add("graphene-tool-status","graphene-multicut"),a.appendChild(Ne({text:"Swap",title:"Swap group",onClick:()=>{s.swapGroup()}})),a.appendChild(Ne({text:"Clear",title:"Clear multicut",onClick:()=>{s.reset()}}));const c=async()=>{d.classList.toggle("disabled",!0);const w=to(this.layer).loadedDataSource.transform.inputSpace.value.scales.map(b=>b/1e-9);n.submitMulticut(w).then(b=>{d.classList.toggle("disabled",!1),b&&e.cancel()})},d=Ne({text:"Submit",title:"Submit multicut",onClick:()=>{c()}});a.appendChild(d);const u=document.createElement("div");u.className="activeGroupIndicator",u.innerHTML="Active Group: ",a.appendChild(u);const{displayState:h}=this.layer,p=h.segmentationGroupState.value,m=h.baseSegmentHighlighting.value,g=h.highlightColor.value;e.bindInputEventMap(aM),e.registerDisposer(()=>{v(),h.baseSegmentHighlighting.value=m,h.highlightColor.value=g});const v=()=>{Ur(p),h.useTempSegmentStatedColors2d.value=!1,h.tempSegmentStatedColors2d.value.clear(),h.tempSegmentDefaultColor2d.value=void 0,h.highlightColor.value=void 0},y=()=>{v(),u.classList.toggle("blueGroup",s.blueGroup.value);const S=s.focusSegment.value;if(S!==void 0){h.baseSegmentHighlighting.value=!0,h.highlightColor.value=s.blueGroup.value?DA:TA,o.useTemporaryVisibleSegments.value=!0,o.useTemporarySegmentEquivalences.value=!0,o.temporaryVisibleSegments.add(S);for(const w of s.segments)o.temporaryVisibleSegments.add(w);for(const w of o.segmentEquivalences.setElements(S))o.temporaryVisibleSegments.has(w)||o.temporarySegmentEquivalences.link(S,w);h.tempSegmentDefaultColor2d.value=PA,h.tempSegmentStatedColors2d.value.set(S,kA);for(const w of s.redSegments)h.tempSegmentStatedColors2d.value.set(w,LA);for(const w of s.blueSegments)h.tempSegmentStatedColors2d.value.set(w,RA);h.useTempSegmentStatedColors2d.value=!0}};y(),e.registerDisposer(s.changed.add(y)),e.registerDisposer(p.segmentEquivalences.changed.add((0,Fe.A)(()=>y(),0))),e.bindAction("swap-group",S=>{S.stopPropagation(),s.swapGroup()}),e.bindAction("set-anchor",S=>{S.stopPropagation();const w=Fu(this,p.visibleSegments);if(!w)return;const{rootId:b,segmentId:x}=w,{focusSegment:E,segments:D}=s;if(E.value===void 0&&(E.value=b.clone()),!P.R.equal(E.value,b)){pe.showTemporaryMessage(`The selected supervoxel has root segment ${b.toString()}, but the supervoxels already selected have root ${E.value.toString()}`,12e3);return}if(!P.R.equal(b,x)){for(const L of D)if(P.R.equal(L,x)){pe.showTemporaryMessage(`Supervoxel ${x.toString()} has already been selected`,7e3);return}}s.activeGroup.add(w)}),e.bindAction("submit",S=>{S.stopPropagation(),c()})}get description(){return"multicut"}}const Fu=(i,e)=>{const{layer:t,mouseState:n}=i,{segmentSelectionState:{value:s,baseValue:r}}=t.displayState;if(!r||!s)return;if(!e.has(s)){pe.showTemporaryMessage("The selected supervoxel is of an unselected segment",7e3);return}const o=rM(t,n);if(o!==void 0)return{rootId:s.clone(),segmentId:r.clone(),position:o}},cM=i=>new Promise((e,t)=>{setTimeout(e,i)});class io extends Ga{constructor(e,t){super(e,{}),this.annotationState=t,this.getBaseSegment=!0;const{inProgressAnnotation:n}=this,{displayState:s}=t;if(!s)return;const{disablePicking:r}=s;this.registerDisposer(n.changed.add(()=>{r.value=n.value!==void 0}))}get annotationLayer(){return this.annotationState}get description(){return"merge line"}toJSON(){return N0}}function A0(i,e){const t=i.relatedSegments[0],n={id:i.id,locked:!1,sink:{position:i.pointA.slice(),rootId:t[0].clone(),segmentId:t[1].clone()}};return e||(n.source={position:i.pointB.slice(),rootId:t[2].clone(),segmentId:t[3].clone()}),n}function dM(i){const{sink:e,source:t}=i;return{id:i.id,type:Re.LINE,pointA:e.position.slice(),pointB:t.position.slice(),relatedSegments:[[e.rootId.clone(),e.segmentId.clone(),t.rootId.clone(),t.segmentId.clone()]],properties:[]}}const M0=20,uM=Ae.fromObject({"at:shift?+enter":{action:"submit"}});class hM extends gi{activate(e){const{graphConnection:{value:t},tool:n}=this.layer;if(!t||!(t instanceof is)){e.cancel();return}const{state:{mergeState:s,timestamp:r}}=t;if(P0(r,e))return;const{merges:o,autoSubmit:a}=s,l=new io(this.layer,t.mergeAnnotationState);n.value=l,e.registerDisposer(()=>{n.value=void 0});const{body:c,header:d}=Vi(e);d.textContent="Merge segments",c.classList.add("graphene-tool-status","graphene-merge-segments"),e.bindInputEventMap(uM);const u=async()=>{o.value.filter(x=>x.locked).length||(h.classList.toggle("disabled",!0),await t.bulkMerge(o.value),h.classList.toggle("disabled",!1))},h=Ne({text:"Submit",title:"Submit merge",onClick:async()=>{u()}});c.appendChild(h),e.bindAction("submit",async x=>{x.stopPropagation(),u()}),c.appendChild(Ne({text:"Clear",title:"Clear pending merges",onClick:()=>{l.deactivate();for(const x of o.value)x.locked||t.deleteMergeSubmission(x)}}));const p=e.registerDisposer(new pn(a)),m=document.createElement("label");m.appendChild(document.createTextNode("auto-submit")),m.title="auto-submit merges",m.appendChild(p.element),c.appendChild(m);const g=document.createElement("div");g.classList.add("graphene-merge-segments-merges"),c.appendChild(g);const v=Vs.make(this.layer.displayState,!0),y=x=>{const E=v.getWithNormalizedId(x);return E.classList.add("neuroglancer-segment-list-entry-double-line"),E},S=x=>{const E=document.createElement("div");E.classList.add("graphene-merge-segments-point");const D=y(Yi(this.layer.displayState,x));return E.appendChild(D),E},w=x=>{const E=document.createElement("div");if(E.classList.add("graphene-merge-segments-submission"),E.appendChild(S(x.sink.rootId)),x.source&&(E.appendChild(document.createElement("div")).textContent="\uA579",E.appendChild(S(x.source.rootId))),x.locked||E.appendChild(Mn({title:"Delete merge",onClick:D=>{D.stopPropagation(),D.preventDefault(),t.deleteMergeSubmission(x)}})),x.status){const D=document.createElement("div");D.classList.add("graphene-merge-segments-submission-status"),D.textContent=x.status,E.appendChild(D)}return E},b=()=>{for(;g.firstChild;)g.removeChild(g.firstChild);for(const x of o.value)g.appendChild(w(x))};e.registerDisposer(o.changed.add(b)),b()}toJSON(){return Vu}get description(){return"merge segments"}}const pM=Ae.fromObject({"at:shift?+enter":{action:"submit"},"at:shift?+control+mousedown0":{action:"add-point"}});class fM extends gi{activate(e){const{layer:t}=this,{graphConnection:{value:n}}=t;if(!n||!(n instanceof is))return;const{state:{findPathState:s},findPathAnnotationState:r}=n,{source:o,target:a,precisionMode:l}=s,c=this.layer.displayState.segmentationGroupState.value,{body:d,header:u}=Vi(e);u.textContent="Find Path",d.classList.add("graphene-tool-status","graphene-find-path");const h=()=>{s.triggerPathUpdate.dispatch()};d.appendChild(Ne({text:"Submit",title:"Submit Find Path",onClick:()=>{h()}})),d.appendChild(Ne({text:"Clear",title:"Clear Find Path",onClick:()=>{s.source.reset(),s.target.reset(),s.centroids.reset()}}));const p=e.registerDisposer(new pn(l)),m=document.createElement("label"),g=document.createElement("span");g.textContent="Precision mode: ",m.appendChild(g),m.title="Precision mode returns a more accurate path, but takes longer.",m.appendChild(p.element),d.appendChild(m);const v=document.createElement("div");v.classList.add("find-path-annotations"),d.appendChild(v);const y=Im();this.registerDisposer(new tn(v,y));const S=()=>{Me(v);const w=[0,0,0],b=[0,1,2],x=[],E="[symbol] 2ch [dim] var(--neuroglancer-column-0-width) [dim] var(--neuroglancer-column-1-width) [dim] var(--neuroglancer-column-2-width) [delete] min-content",I=[o,a].map(L=>L.value?.annotationReference?.value).filter(L=>L);for(const L of I){const[N,k]=xy(this.layer,L,r,E,b,x);for(const[O,V]of k.entries())w[O]=V;v.appendChild(N)}for(const[L,N]of w.entries())v.style.setProperty(`--neuroglancer-column-${L}-width`,`${N+2}ch`)};s.changed.add(S),S(),e.bindInputEventMap(pM),e.bindAction("submit",w=>{w.stopPropagation(),h()}),e.bindAction("add-point",w=>{w.stopPropagation(),(async()=>{if(o.value){if(!a.value){const b=Fu(this,c.visibleSegments);b&&(a.value=b)}}else{const b=Fu(this,c.visibleSegments);b&&(o.value=b)}})()})}toJSON(){return Bu}get description(){return"find path"}}sn(Ct,_u,i=>new lM(i,!0)),sn(Ct,Vu,i=>new hM(i,!0)),sn(Ct,Bu,i=>new fM(i,!0));const N0="annotateMergeLine";Cr(N0,(i,e)=>new io(i,e));/** + * @license + * Copyright 2018 The Neuroglancer Authors + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("graphene",()=>new JA);/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function gM(i,e,t){const n=window.outerHeight-window.innerHeight+window.innerHeight/2-t/2,s=window.innerWidth/2-e/2;return window.open(i,void 0,`toolbar=no, menubar=no, width=${e}, height=${t}, top=${n}, left=${s}`)}async function O0(i,e,t,n,s){const r=new pe(!1,!0),o=new Promise(a=>{function l(c,d){r.element.textContent=c+" ";const u=document.createElement("button");u.textContent=d,r.element.appendChild(u),u.addEventListener("click",()=>{l(n,"Retry");const h=gM(i,400,650),p=()=>{h?.close()};window.addEventListener("beforeunload",p);const m=setInterval(()=>{h?.closed&&(clearInterval(m),l(s,"Retry"))},1e3),g=async v=>{v.source===h&&(clearInterval(m),window.removeEventListener("message",g),window.removeEventListener("beforeunload",p),p(),a(v.data))};window.addEventListener("message",g)})}l(e,t)});try{return await o}finally{r.dispose()}}async function mM(i){const e=await O0(`${i}/api/v1/authorize`,`middleauth server ${i} login required.`,"Login",`Waiting for login to middleauth server ${i}...`,`Login window closed for middleauth server ${i}.`);(0,f.Rf)(e);const t=(0,f.cQ)(e,"token",f.zr),n=(0,f.cQ)(e,"app_urls",f.si);return{tokenType:"Bearer",accessToken:t,url:i,appUrls:n}}async function vM(i,e){return await O0(i,`Before you can access ${e}, you need to accept its Terms of Service.`,"Open","Waiting for Terms of Service agreement...",`Terms of Service closed for ${e}.`)==="success"}const _0="auth_token_v2";function yM(i){const e=localStorage.getItem(`${_0}_${i}`);return e?JSON.parse(e):null}function SM(i,e){localStorage.setItem(`${_0}_${i}`,JSON.stringify(e))}class bM extends Nn{constructor(e){super(),this.serverUrl=e,this.alreadyTriedLocalStorage=!1,this.get=Xn(async()=>{let t;return this.alreadyTriedLocalStorage||(this.alreadyTriedLocalStorage=!0,t=yM(this.serverUrl)),t||(t=await mM(this.serverUrl),SM(this.serverUrl,t)),t})}}class CM extends Error{constructor(e){super(),this.url=e}}class wM extends Nn{constructor(e,t){super(),this.serverUrl=e,this.credentialsManager=t,this.credentials=void 0,this.agreedToTos=!1,this.get=Xn(async()=>{if(this.credentials&&this.agreedToTos)return this.credentials.credentials;this.agreedToTos=!1;const n=await fetch(`${this.serverUrl}/auth_info`).then(o=>o.json()),s=this.credentialsManager.getCredentialsProvider("middleauth",n.login_url);if(this.credentials=await s.get(this.credentials),this.credentials.credentials.appUrls.includes(this.serverUrl))return this.credentials.credentials;throw new pe(!1).setText(`middleauth: unverified app ${this.serverUrl}`),new CM(this.serverUrl)}),this.errorHandler=async(n,s)=>{const{status:r}=n;if(r===401)return"refresh";if(r===403){const{response:o}=n;if(o){const{headers:a}=o;if(a.get("content-type")==="application/json"){const c=await o.json();if(c.error&&c.error==="missing_tos"){const d=new URL(c.data.tos_form_url);if(d.searchParams.set("client","ng"),await vM(d.toString(),c.data.tos_name))return this.agreedToTos=!0,"refresh"}}}if(!s.accessToken)return"refresh"}throw n}}}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Zn.register("middleauth",i=>new bM(i)),Zn.register("middleauthapp",(i,e)=>new wM(i,e));var Uu=G(5926);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class xM extends it(lt()(Kn),Uu.j){}class EM extends ln{constructor(e,t,n,s){super(e),this.credentialsProvider=t,this.multiscaleMetadata=n,this.scales=s;let r,o;if(s.forEach((u,h)=>{if(u!==void 0){if(o===void 0&&(o=h),r!==void 0&&u.dataType!==r)throw new Error(`Scale s${h} has data type ${R[u.dataType]} but expected ${R[r]}.`);r=u.dataType}}),r===void 0)throw new Error("At least one scale must be specified.");const a=n.scales[o],l=s[o];this.dataType=r,this.volumeType=St.IMAGE,this.baseScaleIndex=o;const c=n.modelSpace,{rank:d}=c;this.modelSpace=Oe({names:c.names,scales:c.scales,units:c.units,boundingBoxes:[{transform:(0,De.nx)(Float64Array,a.downsamplingFactor,!1),box:{lowerBounds:new Float64Array(d),upperBounds:new Float64Array(l.size)}}],coordinateArrays:c.coordinateArrays})}get rank(){return this.modelSpace.rank}getSources(e){const{scales:t,rank:n}=this,s=this.multiscaleMetadata.scales;return(0,F.RO)(t.filter(r=>r!==void 0).map((r,o)=>{const a=s[o],l=(0,De.nx)(Float32Array,a.downsamplingFactor);return qi({rank:n,chunkToMultiscaleTransform:l,dataType:r.dataType,upperVoxelBound:r.size,volumeType:this.volumeType,chunkDataSizes:[r.chunkSize],volumeSourceOptions:e}).map(c=>({chunkSource:this.chunkManager.getChunkSource(xM,{credentialsProvider:this.credentialsProvider,spec:c,parameters:{url:a.url,encoding:r.encoding}}),chunkToMultiscaleTransform:l}))}))}}class TM{constructor(e){(0,f.Rf)(e),this.dataType=(0,f.cQ)(e,"dataType",n=>(0,f.sl)(n,R)),this.size=Float32Array.from((0,f.cQ)(e,"dimensions",n=>(0,f.$v)(n,f.We))),this.chunkSize=(0,f.cQ)(e,"blockSize",n=>(0,f.Xu)(new Uint32Array(this.size.length),n,f.We));let t;(0,f.MM)(e,"compression",n=>{t=(0,f.cQ)(n,"type",s=>(0,f.sl)(s,Uu.r))}),t===void 0&&(t=(0,f.cQ)(e,"compressionType",n=>(0,f.sl)(n,Uu.r))),this.encoding=t}}function DM(i,e,t){return Promise.all(t.scales.map(async n=>{const s=await V0(i,e,n.url,!0);if(s!==void 0)return new TM(s)}))}function IM(i){let{protocol:e,host:t,path:n}=(0,ke.Dl)(i);n.endsWith("/")&&(n=n.substring(0,n.length-1));const s=[];for(;;){s.push(`${e}://${t}${n}/attributes.json`);const r=n.lastIndexOf("/");if(r===-1)break;n=n.substring(0,r)}return s}function LM(i,e,t,n){return i.memoize.getUncounted({type:"n5:attributes.json",url:t,credentialsProvider:xt(e)},()=>Nt(e,t,{},ke.cj).then(s=>{try{return(0,f.Rf)(s)}catch(r){throw new Error(`Error reading attributes from ${t}: ${r.message}`)}}).catch(s=>{if((0,ke.El)(s))return n?void 0:{};throw s}))}async function V0(i,e,t,n){const s=IM(t),r=await Promise.all(s.map((o,a)=>LM(i,e,o,n&&a===s.length-1)));if(r.indexOf(void 0)===-1)return r.reverse(),Object.assign({},...r)}function Di(i,e){if(i!==-1&&e!==i)throw new Error(`Rank mismatch, received ${e} but expected ${i}`);return e}function B0(i){return Float64Array.from((0,f.$v)(i,f.Mo))}function F0(i){const e=(0,f.J6)(i);if(e.length===0)throw new Error("Expected non-empty array");let t=-1;return{all:(0,f.$v)(e,s=>{const r=B0(s);return t=Di(t,r.length),r}),single:void 0,rank:t}}function RM(i){const e=(0,f.J6)(i);if(e.length===0)throw new Error("Expected non-empty array");if(Array.isArray(e[0]))return F0(e);const t=B0(i);return{all:void 0,single:t,rank:t.length}}const kM=["x","y","z","t","c"];function PM(i){const e=kM.slice(0,i);for(;e.length{const p=Float64Array.from((0,f.$v)(h,f.Mo));return t=Di(t,p.length),p}),s=(0,f.MM)(e,"axes",h=>{const p=(0,f.$v)(h,f.zr);return t=Di(t,p.length),p}),r=(0,f.MM)(e,"units",h=>{const p=(0,f.$v)(h,Ph);return t=Di(t,p.length),p}),o={unit:"m",exponent:-9},a,l;(0,f.MM)(e,"downsamplingFactors",h=>{const{single:p,all:m,rank:g}=RM(h);t=Di(t,g),p!==void 0&&(a=p),m!==void 0&&(l=m)}),(0,f.MM)(e,"pixelResolution",h=>{o=(0,f.cQ)(h,"unit",Ph),(0,f.MM)(h,"dimensions",p=>{n=Float64Array.from((0,f.$v)(p,f.Mo)),t=Di(t,n.length)})}),(0,f.MM)(e,"scales",h=>{const{all:p,rank:m}=F0(h);t=Di(t,m),l=p});const c=(0,f.MM)(e,"dimensions",h=>{const p=(0,f.$v)(h,f.We);return t=Di(t,p.length),p});if(t===-1)throw new Error("Unable to determine rank of dataset");r===void 0&&(r=new Array(t),r.fill(o)),n===void 0&&(n=new Float64Array(t),n.fill(1));for(let h=0;h{(0,f.Rf)(h);for(let p=0;py)},r[p]={unit:"",exponent:0},n[p]=1}}}),s===void 0&&(s=PM(t));const u=Oe({rank:t,valid:!0,names:s,scales:n,units:r.map(h=>h.unit),coordinateArrays:d});if(c===void 0){if(l===void 0)throw new Error("Not valid single-resolution or multi-resolution dataset");return{modelSpace:u,url:i,attributes:e,scales:l.map((h,p)=>({url:`${i}/s${p}`,downsamplingFactor:h}))}}return a===void 0&&(a=new Float64Array(t),a.fill(1)),{modelSpace:u,url:i,attributes:e,scales:[{url:i,downsamplingFactor:a}]}}class MM extends Jt{get description(){return"N5 data source"}get(e){let{providerUrl:t}=e;return t.endsWith("/")&&(t=t.substring(0,t.length-1)),e.chunkManager.memoize.getUncounted({type:"n5:MultiscaleVolumeChunkSource",providerUrl:t},async()=>{const{url:n,credentialsProvider:s}=wn(t,e.credentialsManager),r=await V0(e.chunkManager,s,n,!1),o=AM(n,r),a=await DM(e.chunkManager,s,o),l=new EM(e.chunkManager,s,o,a);return{modelTransform:wt(l.modelSpace),subsources:[{id:"default",default:!0,url:void 0,subsource:{volume:l}},{id:"bounds",default:!0,url:void 0,subsource:{staticAnnotations:xn(l.modelSpace.bounds)}}]}})}completeUrl(e){return ts(e.credentialsManager,e.providerUrl,e.cancellationToken)}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("n5",()=>new MM);/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function U0(i){return new Error(`ngauth server ${i} does not allow requests from Neuroglancer instance ${self.origin}`)}async function NM(i){const e=new pe(!1);function t(s,r){e.element.textContent=s+" ";const o=document.createElement("button");o.textContent=r,e.element.appendChild(o),o.addEventListener("click",()=>{window.open(`${i}/login?origin=${encodeURIComponent(self.origin)}`),t(`Waiting for login to ngauth server ${i}...`,"Retry")})}const n=new Promise((s,r)=>{function o(a){if((a.origin||a.originalEvent.origin)!==i)return;const c=()=>{window.removeEventListener("message",o,!1)},{data:d}=a;a.data==="badorigin"&&(c(),r(U0(i)));try{(0,f.Rf)(d);const u=(0,f.cQ)(d,"token",f.zr);c(),s(u)}catch{console.log("ngauth: Received unexpected message from ${serverUrl}",a)}}window.addEventListener("message",o,!1)});t(`ngauth server ${i} login required.`,"Login");try{return{token:await n}}finally{e.dispose()}}class OM extends Nn{constructor(e){super(),this.serverUrl=e,this.get=Xn(async()=>{const t=await fetch(`${this.serverUrl}/token`,{method:"POST",credentials:"include"});switch(t.status){case 200:return{token:await t.text()};case 401:return await NM(this.serverUrl);case 403:throw U0(this.serverUrl);default:throw ke.j$.fromResponse(t)}})}}class _M extends Nn{constructor(e,t,n){super(),this.ngauthCredentialsProvider=e,this.serverUrl=t,this.bucket=n,this.get=Xn(async()=>({tokenType:"Bearer",accessToken:(await(0,Ka.R)(this.ngauthCredentialsProvider,`${this.serverUrl}/gcs_token`,{method:"POST"},ke.cj,(r,o)=>({...o,body:JSON.stringify({token:r.token,bucket:this.bucket})}),r=>{const{status:o}=r;if(o===401)return"refresh";throw r})).token}))}}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Zn.register("ngauth",i=>new OM(i)),Zn.register("ngauth_gcs",(i,e)=>new _M(e.getCredentialsProvider("ngauth",i.authServer),i.authServer,i.bucket));/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function $0(i){return new Error(`Nggraph server ${i} does not allow requests from Neuroglancer instance ${self.origin}`)}async function VM(i){const e=new pe(!1);function t(s,r){e.element.textContent=s+" ";const o=document.createElement("button");o.textContent=r,e.element.appendChild(o),o.addEventListener("click",()=>{window.open(`${i}/login?origin=${encodeURIComponent(self.origin)}`),t(`Waiting for login to nggraph server ${i}...`,"Retry")})}const n=new Promise((s,r)=>{function o(a){if((a.origin||a.originalEvent.origin)!==i||typeof a.data!="string")return;const c=()=>{window.removeEventListener("message",o,!1)};a.data==="badorigin"?(c(),r($0(i))):(c(),s(a.data))}window.addEventListener("message",o,!1)});t(`Nggraph server ${i} login required.`,"Login");try{return{token:await n}}finally{e.dispose()}}class BM extends Nn{constructor(e){super(),this.serverUrl=e,this.get=Xn(async()=>{const t=await fetch(`${this.serverUrl}/token`,{method:"POST",credentials:"include"});switch(t.status){case 200:return{token:await t.text()};case 401:return await VM(this.serverUrl);case 403:throw $0(this.serverUrl);default:throw ke.j$.fromResponse(t)}})}}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const FM="^(https?://[^/]+)/(.*)$";function UM(i){return(0,f.Rf)(i),{id:(0,f.cQ)(i,"id",e=>P.R.parseString((0,f.zr)(e))),baseSegments:(0,f.cQ)(i,"base_segment_ids",e=>(0,f.$v)(e,t=>P.R.parseString((0,f.zr)(t)))),baseSegmentParents:(0,f.cQ)(i,"base_segment_parent_ids",e=>(0,f.$v)(e,t=>P.R.parseString((0,f.zr)(t)))),name:(0,f.cQ)(i,"name",f.zr),tags:(0,f.cQ)(i,"tags",f.si),numVoxels:(0,f.cQ)(i,"num_voxels",f.bX),bounds:(0,f.cQ)(i,"bounds",e=>(0,f.$v)(e,t=>(0,f.zo)(t))),lastLogId:(0,f.cQ)(i,"last_log_id",e=>e==null?null:P.R.parseString((0,f.zr)(e)))}}let G0=0;class $M extends _d{constructor(e,t){super(e,t),this.debouncedVisibleSegmentsChanged=this.registerCancellable((0,Fe.A)(()=>this.visibleSegmentsChanged(),0)),this.segmentQueries=new Map,this.ignoreVisibleSegmentsChanged=!1,this.segmentEquivalencesChanged=this.registerCancellable((0,Fe.A)(()=>{this.debouncedVisibleSegmentsChanged.flush(),this.segmentEquivalencesChanged.cancel();const{segmentQueries:s}=this,{segmentEquivalences:r}=this.segmentsState;r.clear();for(const[o,a]of s){if(a.current===void 0||(0,Rt.YR)(a.id))continue;const{id:l,baseSegments:c}=a.current;if(c.length>0){for(const d of c)r.link(d,l);a.addedEquivalences=!0}else a.addedEquivalences=!1}},0));const n=()=>{this.ignoreVisibleSegmentsChanged||this.debouncedVisibleSegmentsChanged()};this.registerDisposer(t.visibleSegments.changed.add(n)),this.registerDisposer(t.temporaryVisibleSegments.changed.add(n)),this.visibleSegmentsChanged()}computeSplit(e,t){const{segmentEquivalences:n}=this.segmentsState,s=n.get(e);if((0,Rt.YR)(s)||!P.R.equal(n.get(t),s))return;const r=this.segmentQueries.get(s.toString());if(r===void 0)return;const{current:o}=r;if(o===void 0)return;const{baseSegments:a,baseSegmentParents:l}=o,c=l.length,d=new Vd.I;for(let m=0;mthis.handleSegmentUpdate(t.id.toString(),s))},n=e.toString();this.segmentQueries.set(n,t),console.log(`adding to segmentQueries: ${n}`)}handleSegmentUpdate(e,t){console.log(`handleSegmentUpdate: ${e}`);const n=this.segmentQueries.get(e);if(t==="invalid"){n.disposer(),console.log(`removing from segmentQueries: ${e} due to invalid`),this.segmentQueries.delete(e);try{this.ignoreVisibleSegmentsChanged=!0,this.segmentsState.visibleSegments.delete(n.id),this.segmentsState.temporaryVisibleSegments.delete(n.id)}finally{this.ignoreVisibleSegmentsChanged=!1}n.addedEquivalences&&this.segmentEquivalencesChanged();return}if(t==="error"){n.current=void 0,n.addedEquivalences&&this.segmentEquivalencesChanged(),console.log(`Error from ${this.graph.serverUrl}/${this.graph.entityName} watching segment ${e}`);return}n.current=t;const s=n.id,r=t.id;if(P.R.equal(r,s))n.current=t,(0,Rt.YR)(n.id)||this.segmentEquivalencesChanged();else{n.id=r;const o=r.toString(),a=this.segmentQueries.get(o);console.log(`removing from segmentQueries: ${e} due to rename -> ${r}`),this.segmentQueries.delete(e);try{this.ignoreVisibleSegmentsChanged=!0,this.segmentsState.visibleSegments.has(s)&&this.segmentsState.visibleSegments.add(r),this.segmentsState.selectedSegments.has(s)&&(this.segmentsState.selectedSegments.delete(s),this.segmentsState.selectedSegments.add(r)),this.segmentsState.temporaryVisibleSegments.has(s)&&(this.segmentsState.temporaryVisibleSegments.delete(s),this.segmentsState.temporaryVisibleSegments.add(r))}finally{this.ignoreVisibleSegmentsChanged=!1}a===void 0?(console.log(`adding to segmentQueries due to rename -> ${r}`),this.segmentQueries.set(o,n),this.segmentEquivalencesChanged()):(t.lastLogId!==null&&(typeof a.current!="object"||a.current.lastLogId===null||P.R.less(a.current.lastLogId,t.lastLogId))&&(a.current=t,this.segmentEquivalencesChanged()),n.disposer())}}visibleSegmentsChanged(){const{segmentsState:e}=this,{segmentQueries:t}=this,n=++G0,s=r=>{for(const o of r.unsafeKeys()){if(P.R.equal(o,Rt.G1))continue;const a=o.toString(),l=t.get(a);if(l!==void 0){l.seenGeneration=n;continue}this.registerVisibleSegment(o.clone())}};s(e.visibleSegments),s(e.temporaryVisibleSegments);for(const[r,o]of t)o.seenGeneration!==n&&(console.log(`removing from segmentQueries due to seenGeneration: ${r}`),t.delete(r),o.disposer(),o.addedEquivalences&&this.segmentEquivalencesChanged())}}class GM extends Od{constructor(e,t,n){super(),this.chunkManager=e,this.serverUrl=t,this.entityName=n,this.startingWebsocket=!1,this.websocket=void 0,this.watchesById=new Map,this.watches=new Set,this.nextWatchId=0,this.numOpenFailures=0}get visibleSegmentEquivalencePolicy(){return Rt.y6.MAX_REPRESENTATIVE|Rt.y6.REPRESENTATIVE_EXCLUDED}startWebsocket(){if(this.startingWebsocket||this.watches.size===0)return;this.startingWebsocket=!0;let e=new pe(!this.numOpenFailures);e.setText(`Opening websocket connection for nggraph://${this.serverUrl}/${this.entityName}`),(async()=>{const{numOpenFailures:t}=this;if(t>1){const o=1e3*Math.min(16,2**t);await new Promise(a=>setTimeout(a,o))}const n=(await Gu(this.chunkManager,this.serverUrl,this.entityName).get()).credentials,s=new URL("/graph/watch/"+encodeURIComponent(n.token),this.serverUrl);s.protocol=s.protocol.replace("http","ws");const r=new WebSocket(s.href);r.onclose=()=>{e!==void 0&&(e.dispose(),e=void 0),++this.numOpenFailures,this.websocket=void 0,this.startingWebsocket=!1,this.watchesById.clear(),this.startWebsocket()},r.onopen=()=>{e!==void 0&&(e.dispose(),e=void 0),this.numOpenFailures=0,this.websocket=r,this.nextWatchId=0;try{for(const o of this.watches){r.send(JSON.stringify({watch:{segment_id:o.segment.toString()}}));const a=this.nextWatchId++;o.watchId=a,this.watchesById.set(a,o)}}catch{}},r.onmessage=o=>{let a,l;try{const c=JSON.parse(o.data);(0,f.Rf)(c);const d=(0,f.cQ)(c,"watch_id",f.bX),u=this.watchesById.get(d);if(u===void 0)return;l=u;const h=(0,f.cQ)(c,"state",f.zr);h==="invalid"||h==="error"?a=h:a=(0,f.cQ)(c,"info",UM)}catch(c){console.log(`Received unexpected websocket message from ${this.serverUrl}:`,o.data,c);return}console.log("got update",a),l.callback(a)}})()}connect(e){const t=e.displayState.segmentationGroupState.value;return new $M(this,t)}trackSegment(e,t){return this.watchSegment(e,n=>{if(n==="invalid")t(null);else{if(n==="error")return;t(n.id)}})}watchSegment(e,t){const n={callback:t,segment:e,watchId:-1};this.watches.add(n);const{websocket:s}=this;if(s!==void 0)try{s.send(JSON.stringify({watch:{segment_id:e.toString()}}));const o=this.nextWatchId++;n.watchId=o,this.watchesById.set(o,n)}catch{}else this.startWebsocket();return()=>{const{websocket:o}=this;if(o!==void 0&&o.readyState===WebSocket.OPEN){const a=n.watchId;this.watchesById.delete(a);try{o.send(JSON.stringify({unwatch:{watch_id:a}}))}catch{}}this.watches.delete(n)}}async merge(e,t){const n=await zu(this.chunkManager,this.serverUrl,this.entityName,"/graph/mutate",{body:JSON.stringify({merge:{anchor:e.toString(),other:t.toString()}}),headers:{"Content-Type":"application/json"},method:"POST"});return(0,f.Rf)(n),(0,f.cQ)(n,"merged",s=>P.R.parseString(s))}async split(e,t){const n=await zu(this.chunkManager,this.serverUrl,this.entityName,"/graph/mutate",{body:JSON.stringify({split:{include:e.toString(),exclude:t.toString()}}),headers:{"Content-Type":"application/json"},method:"POST"});return(0,f.Rf)(n),{include:(0,f.cQ)(n,"include",s=>P.R.parseString(s)),exclude:(0,f.cQ)(n,"exclude",s=>P.R.parseString(s))}}}function z0(i){const e=i.match(FM);if(e===null)throw new Error(`Invalid nggraph url: ${JSON.stringify(i)}`);return{serverUrl:e[1],id:e[2]}}function $u(i,e,t,n,s=Je.fx){return(0,Ka.R)(i,`${e}${t}`,n,ke.cj,(r,o)=>{const a=new Headers(o.headers);return a.set("Authorization",r.token),{...o,headers:a}},r=>{const{status:o}=r;if(o===401)return"refresh";throw r},s)}function zM(i,e,t,n,s=Je.fx){return $u(W0(i,e),e,t,n,s)}class WM extends Nn{constructor(e,t,n){super(),this.parentCredentialsProvider=e,this.serverUrl=t,this.entityName=n,this.get=Xn(async()=>{const s=await $u(this.parentCredentialsProvider,this.serverUrl,"/entity_token",{body:JSON.stringify({entity:this.entityName}),headers:{"Content-Type":"application/json"},method:"POST"});return{token:s.token,entityType:s.entity_type,role:s.role}})}}function W0(i,e){return i.memoize.getUncounted({type:"nggraph:credentialsProvider",serverUrl:e},()=>new BM(e))}function Gu(i,e,t){return i.memoize.getUncounted({type:"nggraph:entityCredentialsProvider",serverUrl:e,entityName:t},()=>new WM(W0(i,e),e,t))}function zu(i,e,t,n,s,r=Je.fx){return $u(Gu(i,e,t),e,n,s,r)}function HM(i){return(0,f.Rf)(i),(0,f.cQ)(i,"entities",e=>(0,f.$v)(e,t=>{(0,f.Rf)(t);const n=(0,f.cQ)(t,"entity",f.zr),s=(0,f.cQ)(t,"entity_type",f.zr),r=(0,f.cQ)(t,"access_role",f.zr);return{id:n,entityType:s,accessRole:r}}))}class JM extends Jt{get description(){return"nggraph data source"}get(e){const{serverUrl:t,id:n}=z0(e.providerUrl);return e.chunkManager.memoize.getUncounted({type:"nggraph:get",serverUrl:t,id:n},async()=>{const s=Gu(e.chunkManager,t,n),{entityType:r}=(await s.get()).credentials;if(r!=="graph")throw new Error(`Unsupported entity type: ${JSON.stringify(r)}`);const{datasource_url:o}=await zu(e.chunkManager,t,n,"/graph/config",{method:"POST"}),a=await e.registry.get({...e,url:o}),l=new GM(e.chunkManager,t,n),c=[...a.subsources,{id:"graph",default:!0,subsource:{segmentationGraph:l}}];return{modelTransform:a.modelTransform,subsources:c}})}async completeUrl(e){const{serverUrl:t,id:n}=z0(e.providerUrl),s=await e.chunkManager.memoize.getUncounted({type:"nggraph:list",serverUrl:t},async()=>HM(await zM(e.chunkManager,t,"/list",{method:"POST"})));return{offset:t.length+1,completions:Ht(n,s,r=>r.id,r=>`${r.entityType} (${r.accessRole})`)}}}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("nggraph",()=>new JM);var H0=G(6435);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class jM extends it(lt()(Kn),H0.C){}class YM extends ln{constructor(e,t,n,s){super(e),this.credentialsProvider=t,this.url=n,this.info=s}get dataType(){return this.info.dataType}get volumeType(){return St.UNKNOWN}get rank(){return this.info.rank}getSources(e){const{info:t}=this,n=De.DA(Float32Array,t.rank+1),s=xv({rank:t.rank,volumeType:St.UNKNOWN,chunkDataSize:t.volumeSize,dataType:t.dataType,upperVoxelBound:Float32Array.from(t.volumeSize),chunkToMultiscaleTransform:n,volumeSourceOptions:e});return[[{chunkSource:this.chunkManager.getChunkSource(jM,{credentialsProvider:this.credentialsProvider,spec:s,parameters:{url:this.url}}),chunkToMultiscaleTransform:n}]]}}function QM(i,e,t,n){return i.rpc.promiseInvoke(H0.Y,{chunkManager:i.addCounterpartRef(),credentialsProvider:Eu(i,e),url:t},n)}function KM(i,e,t){return i.memoize.getUncounted({type:"nifti/getVolume",url:t},async()=>{const{url:n,credentialsProvider:s}=wn(t,e),r=await QM(i,s,n,Je.fx),o=new YM(i,s,n,r),a={lowerBounds:new Float64Array(r.rank),upperBounds:Float64Array.from(r.volumeSize)},l=Oe({rank:r.rank,names:r.sourceNames,scales:r.sourceScales,units:r.units,boundingBoxes:[En(a)]}),c=Oe({rank:r.rank,names:r.viewNames,scales:r.viewScales,units:r.units});return{subsources:[{id:"default",default:!0,subsource:{volume:o}},{id:"bounds",default:!0,subsource:{staticAnnotations:xn(a)}}],modelTransform:{sourceRank:r.rank,rank:r.rank,inputSpace:l,outputSpace:c,transform:r.transform}}})}class qM extends Jt{get description(){return"Single NIfTI file"}get(e){return KM(e.chunkManager,e.credentialsManager,e.providerUrl)}completeUrl(e){return ts(e.credentialsManager,e.providerUrl,e.cancellationToken)}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("nifti",()=>new qM);/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class XM extends Jt{get description(){return"Wavefront OBJ mesh file"}async get(e){const t=await IS(e.chunkManager,e.credentialsManager,e.url),n=Oe({rank:3,names:["x","y","z"],units:["m","m","m"],scales:Float64Array.of(1e-9,1e-9,1e-9)});return{modelTransform:wt(n),subsources:[{id:"default",default:!0,subsource:{singleMesh:t}}]}}completeUrl(e){return ts(e.credentialsManager,e.providerUrl,e.cancellationToken)}}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("obj",()=>new XM);/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("precomputed",()=>new ZS);var ZM=G(8997);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const eN=new Set(["jpg","raw16"]),tN=it(Kn,ZM.vc);class nN extends tN{}const iN=new Set(["COMPLETE","READ_ONLY"]),sN=new Set(["LOADING"]);function rN(i){const e=(0,f.$v)(i,f.Rf);if(e.length<1)throw new Error("No stacks found for owner object.");const t=new Map,n=(0,f.cQ)(e[0],"stackId",aN);for(const s of e){const r=(0,f.cQ)(s,"stackId",oN),o=lN(s);if(o!==void 0){const a=o.project;let l=t.get(a);if(l===void 0){const c=new Map;t.set(a,{stacks:c}),l=t.get(a)}l.stacks.set(r,o)}}return{owner:n,projects:t}}function oN(i){return(0,f.Rf)(i),(0,f.cQ)(i,"stack",f.zr)}function aN(i){return(0,f.Rf)(i),(0,f.cQ)(i,"owner",f.zr)}function lN(i){(0,f.Rf)(i);const e=(0,f.cQ)(i,"state",f.zr);let t=[],n=C.eR.create(),s=C.eR.create();if(iN.has(e)){const a=(0,f.cQ)(i,"stats",f.Rf);n=dN(a),s=cN(a),Object.prototype.hasOwnProperty.call(a,"channelNames")&&(t=uN(a))}else if(!sN.has(e))return;const r=(0,f.cQ)(i,"currentVersion",hN),o=(0,f.cQ)(i,"stackId",pN);return{lowerVoxelBound:n,upperVoxelBound:s,voxelResolution:r,project:o,channels:t}}function cN(i){(0,f.Rf)(i);const e=(0,f.cQ)(i,"stackBounds",f.Rf),t=C.eR.create();return t[0]=(0,f.cQ)(e,"maxX",f._D)+1,t[1]=(0,f.cQ)(e,"maxY",f._D)+1,t[2]=(0,f.cQ)(e,"maxZ",f._D)+1,t}function dN(i){(0,f.Rf)(i);const e=(0,f.cQ)(i,"stackBounds",f.Rf),t=C.eR.create();return t[0]=(0,f.cQ)(e,"minX",f._D),t[1]=(0,f.cQ)(e,"minY",f._D),t[2]=(0,f.cQ)(e,"minZ",f._D),t}function uN(i){return(0,f.Rf)(i),(0,f.cQ)(i,"channelNames",e=>(0,f.$v)(e,f.zr))}function hN(i){(0,f.Rf)(i);const e=C.eR.create();try{e[0]=(0,f.cQ)(i,"stackResolutionX",f._D),e[1]=(0,f.cQ)(i,"stackResolutionY",f._D),e[2]=(0,f.cQ)(i,"stackResolutionZ",f._D)}catch{e[0]=1,e[1]=1,e[2]=1}return e}function pN(i){return(0,f.Rf)(i),(0,f.cQ)(i,"project",f.zr)}class fN extends ln{constructor(e,t,n,s,r,o,a){super(e),this.baseUrl=t,this.ownerInfo=n,this.project=r,this.parameters=a;const l=n.projects.get(r);if(l===void 0)throw new Error(`Specified project ${JSON.stringify(r)} does not exist for specified owner ${JSON.stringify(n.owner)}`);if(s===void 0){const h=Array.from(l.stacks.keys());if(h.length!==1)throw new Error(`Dataset contains multiple stacks: ${JSON.stringify(h)}`);s=h[0]}const c=l.stacks.get(s);if(c===void 0)throw new Error(`Specified stack ${JSON.stringify(s)} is not one of the supported stacks: `+JSON.stringify(Array.from(l.stacks.keys())));this.stack=s,this.stackInfo=c,o!==void 0&&o.length>0&&(this.channel=o),this.minIntensity=(0,f.zB)(a.minIntensity),this.maxIntensity=(0,f.zB)(a.maxIntensity),this.maxTileSpecsToRender=(0,f.zB)(a.maxTileSpecsToRender),this.filter=(0,f.uS)(a.filter),this.minX=(0,f.zB)(a.minX),this.minY=(0,f.zB)(a.minY),this.minZ=(0,f.zB)(a.minZ),this.maxX=(0,f.zB)(a.maxX),this.maxY=(0,f.zB)(a.maxY),this.maxZ=(0,f.zB)(a.maxZ),this.minX!==void 0&&(c.lowerVoxelBound[0]=this.minX),this.minY!==void 0&&(c.lowerVoxelBound[1]=this.minY),this.minZ!==void 0&&(c.lowerVoxelBound[2]=this.minZ),this.maxX!==void 0&&(c.upperVoxelBound[0]=this.maxX),this.maxY!==void 0&&(c.upperVoxelBound[1]=this.maxY),this.maxZ!==void 0&&(c.upperVoxelBound[2]=this.maxZ);let d=(0,f.z$)(a.encoding);if(d===void 0)d="jpg";else if(!eN.has(d))throw new Error(`Invalid encoding: ${JSON.stringify(d)}.`);this.encoding=d,this.numLevels=(0,f.zB)(a.numlevels),this.dims=C.eR.create();let u=(0,f.zB)(a.tilesize);u===void 0&&(u=1024),this.dims[0]=u,this.dims[1]=u,this.dims[2]=1}get dataType(){return this.parameters.encoding==="raw16"?R.UINT16:R.UINT8}get volumeType(){return St.IMAGE}get rank(){return 3}getSources(e){const t=[];let n=this.numLevels;n===void 0&&(n=gN(this.stackInfo,this.dims[0]));const{lowerVoxelBound:s,upperVoxelBound:r}=this.stackInfo;for(let o=0;o=t)return 1;let n=0;for(;t>e;)t=t/2,n++;return n}function dl(i,e,t){return i.memoize.getUncounted({type:"render:getOwnerInfo",hostname:e,owner:t},()=>(0,ke.vd)(`${e}/render-ws/v1/owner/${t}/stacks`).then(n=>n.json()).then(rN))}const mN=/^([^/?]+)(?:\/([^/?]+))?(?:\/([^/?]+))(?:\/([^/?]*))?(?:\?(.*))?$/,J0=/^((?:(?:(?:http|https):\/\/[^,/]+)[^/?]))\/(.*)$/;function vN(i,e){let t,n;{const d=e.match(J0);if(d===null)throw new Error(`Invalid render volume path: ${JSON.stringify(e)}`);t=d[1],n=d[2]}const s=n.match(mN);if(s===null)throw new Error(`Invalid volume path ${JSON.stringify(n)}`);const r=s[1],o=s[2],a=s[3],l=s[4],c=(0,f.bL)(s[5]||"");return i.memoize.getUncounted({type:"render:MultiscaleVolumeChunkSource",hostname:t,path:n},async()=>{const d=await dl(i,t,r),u=new fN(i,t,d,a,o,l,c),h=Oe({rank:3,names:["x","y","z"],units:["m","m","m"],scales:Float64Array.from(u.stackInfo.voxelResolution,m=>m/1e9),boundingBoxes:[En({lowerBounds:new Float64Array(u.stackInfo.lowerVoxelBound),upperBounds:new Float64Array(u.stackInfo.upperVoxelBound)})]});return{modelTransform:wt(h),subsources:[{id:"default",default:!0,subsource:{volume:u}},{id:"bounds",default:!0,subsource:{staticAnnotations:xn(h.bounds)}}]}})}async function yN(i,e,t){const n=t.match(/^(?:([^/]+)(?:\/([^/]*))?(?:\/([^/]*))?(\/.*?)?)?$/);if(n===null||n[2]===void 0)throw null;if(n[3]===void 0){const d=n[2]||"",u=await dl(i,e,n[1]),h=Ht(d,u.projects,p=>p[0]+"/",()=>{});return{offset:n[1].length+1,completions:h}}if(n[4]===void 0){const d=n[3]||"",h=(await dl(i,e,n[1])).projects.get(n[2]);if(h===void 0)throw null;const p=Ht(d,h.stacks,m=>m[0]+"/",m=>m[1].project);return{offset:n[1].length+n[2].length+2,completions:p}}const s=n[4].substr(1)||"",o=(await dl(i,e,n[1])).projects.get(n[2]);if(o===void 0)throw null;const a=o.stacks.get(n[3]);if(a===void 0)throw null;const l=a.channels;if(l.length===0)throw null;const c=Ht(s,l,d=>d,()=>{});return{offset:n[1].length+n[2].length+n[3].length+3,completions:c}}async function SN(i,e){const t=i.match(J0);if(t===null)throw null;const n=t[1],s=t[2],r=await yN(e,n,s);return yi(t[1].length+1,r)}class bN extends Jt{get description(){return"Render"}get(e){return vN(e.chunkManager,e.providerUrl)}completeUrl(e){return SN(e.providerUrl,e.chunkManager)}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("render",()=>new bN);/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class CN extends Jt{get description(){return"VTK mesh file"}async get(e){const t=await IS(e.chunkManager,e.credentialsManager,e.url),n=Oe({rank:3,names:["x","y","z"],units:["m","m","m"],scales:Float64Array.of(1e-9,1e-9,1e-9)});return{modelTransform:wt(n),subsources:[{id:"default",default:!0,subsource:{singleMesh:t}}]}}completeUrl(e){return ts(e.credentialsManager,e.providerUrl,e.cancellationToken)}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("vtk",()=>new CN);var _t=G(2334);/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Wu(i,e,t){(0,f.Rf)(i);const n=(0,f.cQ)(i,"name",r=>e((0,f.zr)(r))),s=(0,f.cQ)(i,"configuration",r=>(r===void 0?r={}:(0,f.Rf)(r),t(r,n)));return{name:n,configuration:s}}/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function wN(i){const{name:e,configuration:t}=Wu(i,n=>{const s=j0.get(n);if(s===void 0)throw new Error(`Unknown codec: ${JSON.stringify(n)}`);return s},n=>n);return{resolver:e,configuration:t}}const j0=new Map;function ss(i){j0.set(i.name,i)}function ul(i,e){const t=[],n=[],s=[],r=[];n.push(e);const o=(0,f.$v)(i,wN),a=o.length;let l=0;for(;l bytes codec");const{codecSpec:c,layoutInfo:d,encodedSize:u,shardingInfo:h}=(()=>{const{resolver:g,configuration:v}=o[l],y=g,{configuration:S,shardingInfo:w,encodedSize:b}=y.resolve(v,e);if(w!==void 0&&l+1!==a)throw new Error("bytes -> bytes codecs not supported following sharding codec");const x=y.getDecodedArrayLayoutInfo(S,e);return{codecSpec:{name:g.name,kind:_t.L.arrayToBytes,configuration:S},layoutInfo:x,encodedSize:b,shardingInfo:w}})();s[l]=d,r.push(u);const p=u,m=[];for(++l;l bytes codec, but received ${JSON.stringify(g.name)} of kind ${_t.L[g.kind]}`);const y=g,{configuration:S,encodedSize:w}=y.resolve(v,p);m.push({name:g.name,kind:g.kind,configuration:S}),r.push(w),++l}for(let g=t.length-1;g>=0;--g)s[g]=o[g].resolver.getDecodedArrayLayoutInfo(t[g].configuration,n[g],s[g+1]);return{[_t.L.arrayToArray]:t,[_t.L.arrayToBytes]:c,[_t.L.bytesToBytes]:m,arrayInfo:n,layoutInfo:s,shardingInfo:h,encodedSize:r}}/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ss({name:"blosc",kind:_t.L.bytesToBytes,resolve(i){return(0,f.Rf)(i),{configuration:{}}}});/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ss({name:"zstd",kind:_t.L.bytesToBytes,resolve(i){return(0,f.Rf)(i),{configuration:{}}}});var xN=G(6742);/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ss({name:"bytes",kind:_t.L.arrayToBytes,resolve(i,e){(0,f.Rf)(i);const t=(0,f.cQ)(i,"endian",s=>{switch(s){case"little":return U.LITTLE;case"big":return U.BIG;case void 0:if(B[e.dataType]===1)return te}throw new Error(`Invalid endian value: ${JSON.stringify(s)}`)}),n=e.chunkShape.reduce((s,r)=>s*r,1);return{configuration:{endian:t},encodedSize:B[e.dataType]*n}},getDecodedArrayLayoutInfo(i,e){return{physicalToLogicalDimension:Array.from(e.chunkShape,(t,n)=>n),readChunkShape:e.chunkShape}}});/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ss({name:"crc32c",kind:_t.L.bytesToBytes,resolve(i,e){let t;return e!==void 0&&(t=e+4),{configuration:{},encodedSize:t}}});/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ss({name:"gzip",kind:_t.L.bytesToBytes,resolve(i){return(0,f.Rf)(i),{configuration:{level:(0,f.cQ)(i,"level",f.bX)}}}});/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var hl=(i=>(i[i.DEFAULT=0]="DEFAULT",i[i.V2=1]="V2",i))(hl||{});/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const ei=new Map;ei.set("|u1",{endianness:U.LITTLE,dataType:R.UINT8}),ei.set("|i1",{endianness:U.LITTLE,dataType:R.INT8});for(const[i,e]of[["<",U.LITTLE],[">",U.BIG]]){for(const t of["u","i"])ei.set(`${i}${t}8`,{endianness:e,dataType:R.UINT64});ei.set(`${i}u2`,{endianness:e,dataType:R.UINT16}),ei.set(`${i}i2`,{endianness:e,dataType:R.INT16}),ei.set(`${i}u4`,{endianness:e,dataType:R.UINT32}),ei.set(`${i}i4`,{endianness:e,dataType:R.INT32}),ei.set(`${i}f4`,{endianness:e,dataType:R.FLOAT32})}function EN(i){const e=ei.get(i);if(e===void 0)throw new Error(`Unsupported numpy data type: ${JSON.stringify(i)}`);return e}/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Y0(i){return(0,f.$v)(i,e=>{if(typeof e!="number"||!Number.isInteger(e)||e<0)throw new Error(`Expected non-negative integer, but received: ${JSON.stringify(e)}`);return e})}function Hu(i,e){return(0,f.Xu)(new Array(e),i,t=>{if(typeof t!="number"||!Number.isInteger(t)||t<=0)throw new Error(`Expected positive integer, but received: ${JSON.stringify(t)}`);return t})}function Ju(i){if(i!=="."&&i!=="/")throw new Error(`Expected "." or "/", but received: ${JSON.stringify(i)}`);return i}const ju=new Map([["",{unit:"",scale:1}],["angstrom",{unit:"m",scale:1e-10}],["foot",{unit:"m",scale:.3048}],["inch",{unit:"m",scale:.0254}],["mile",{unit:"m",scale:1609.34}],["parsec",{unit:"m",scale:0x6da012f95c9e88}],["yard",{unit:"m",scale:.9144}],["minute",{unit:"s",scale:60}],["hour",{unit:"s",scale:60*60}],["day",{unit:"s",scale:60*60*24}]]);for(const i of["meter","second"])for(const e of Bl){const{longPrefix:t,prefix:n}=e;if(t===void 0)continue;const s={unit:i[0],scale:10**e.exponent};ju.set(`${t}${i}`,s),ju.set(`${n}${i[0]}`,s)}function TN(i){if(i===null)return{scale:1,unit:""};if(typeof i!="string")throw new Error(`Expected string but received: ${JSON.stringify(i)}`);const e=i.trim(),t=/^([-+]?(?:\.[0-9]+|[0-9]+(?:\.[0-9]*)?)(?:[eE][-+]?\d+)?)\s*(.*)/,n=e.match(t);let s,r;n===null?(s=1,r=e):(s=Number(n[1]),r=n[2]);const o=ju.get(r);if(o===void 0)throw new Error(`Unsupported unit: ${JSON.stringify(r)}`);return{unit:o.unit,scale:s*o.scale}}function Q0(i,e){switch(i){case R.UINT8:case R.INT8:case R.UINT16:case R.INT16:case R.UINT32:case R.INT32:case R.UINT64:if(typeof e!="number"||!Number.isInteger(e))throw new Error(`Expected integer but received: ${JSON.stringify(e)}`);return e;case R.FLOAT32:if(typeof e=="number")return e;if(typeof e=="string"){if(e==="Infinity")return Number.POSITIVE_INFINITY;if(e==="-Infinity")return Number.NEGATIVE_INFINITY;if(e==="NaN")return new Float32Array(Uint32Array.of(2143289344).buffer)[0];if(e.match(/^0x[a-fA-F0-9]+$/))return new Float32Array(Uint32Array.of(Number(e)).buffer)[0]}throw new Error(`Expected number, "Infinity", "-Infinity", "NaN", or hex string but received: ${JSON.stringify(e)}`)}}function DN(i,e){try{(0,f.Rf)(i),(0,f.cQ)(i,"zarr_format",m=>{(0,f.qi)(m,3)});const t=(0,f.cQ)(i,"node_type",m=>{if(e!==void 0&&(0,f.qi)(m,e),m!=="array"&&m!=="group")throw new Error(`Expected "array" or "group" but received: ${JSON.stringify(m)}`);return m});if(e=t,t==="group")return{zarrVersion:3,nodeType:"group",userAttributes:(0,f.MM)(i,"attributes",f.Rf,{})};const n=(0,f.cQ)(i,"shape",Y0),s=n.length,r=(0,f.cQ)(i,"dimension_names",m=>(0,f.ZD)(m??void 0,s)),o=(0,f.cQ)(i,"data_type",m=>(0,f.sl)(m,R,/^[a-z0-9]+$/)),{configuration:a}=(0,f.cQ)(i,"chunk_grid",m=>Wu(m,g=>(0,f.qi)(g,"regular"),g=>(0,f.cQ)(g,"chunk_shape",v=>Hu(v,s)))),{userAttributes:l,dimensionUnits:c}=(0,f.cQ)(i,"attributes",m=>{m===void 0&&(m={}),(0,f.Rf)(m);const g=(0,f.cQ)(m,"dimension_units",v=>(0,f.ZD)(v,s));return{userAttributes:m,dimensionUnits:g}}),{configuration:d,name:u}=(0,f.cQ)(i,"chunk_key_encoding",m=>Wu(m,g=>(0,f.sl)(g,hl,/^(v2|default)$/),(g,v)=>(0,f.MM)(g,"separator",Ju,v===hl.DEFAULT?"/":"."))),h=(0,f.cQ)(i,"fill_value",m=>Q0(o,m)),p=(0,f.cQ)(i,"codecs",m=>ul(m,{dataType:o,chunkShape:a}));return{zarrVersion:3,nodeType:t,rank:s,shape:n,chunkShape:a,dataType:o,fillValue:h,dimensionNames:r,dimensionUnits:c,chunkKeyEncoding:u,dimensionSeparator:d,userAttributes:l,codecs:p}}catch(t){const n=e===void 0?"":`${e} `;throw new Error(`Error parsing zarr v3 ${n}metadata: ${t.message}`)}}function IN(i,e,t){try{(0,f.Rf)(i),(0,f.cQ)(i,"zarr_format",p=>{(0,f.qi)(p,2)});const n=(0,f.cQ)(i,"shape",Y0),s=n.length,r=(0,f.cQ)(i,"chunks",p=>Hu(p,s)),o=(0,f.cQ)(i,"order",p=>{if(p!=="C"&&p!=="F")throw new Error(`Expected "C" or "F", but received: ${JSON.stringify(p)}`);return p}),a=(0,f.MM)(i,"dimension_separator",t===void 0?Ju:p=>(0,f.qi)(p,t),t??"."),l=(0,f.cQ)(i,"dtype",p=>EN((0,f.zr)(p))),c=l.dataType,d=(0,f.cQ)(i,"fill_value",p=>p===null?0:Q0(c,p)),u=[];o==="F"&&u.push({name:"transpose",configuration:{order:Array.from(n,(p,m)=>s-m-1)}}),u.push({name:"bytes",configuration:{endian:l.endianness===U.LITTLE?"little":"big"}}),(0,f.cQ)(i,"compressor",p=>{if(p===null)return;(0,f.Rf)(p);const m=(0,f.cQ)(p,"id",f.zr);switch(m){case"blosc":u.push({name:"blosc",configuration:{cname:(0,f.cQ)(p,"cname",f.zr),clevel:(0,f.cQ)(p,"clevel",f.bX),typesize:B[c],shuffle:(0,f.cQ)(p,"shuffle",g=>{switch(g){case-1:return B[c]===1?"bitshuffle":"shuffle";case 0:return"noshuffle";case 1:return"shuffle";case 2:return"bitshuffle"}throw new Error(`Invalid value: ${JSON.stringify(g)}`)}),blocksize:(0,f.MM)(p,"blocksize",f.bX,0)}});break;case"zlib":case"gzip":u.push({name:"gzip",configuration:{level:(0,f.cQ)(p,"level",f.bX)}});break;case"zstd":u.push({name:"zstd",configuration:{level:(0,f.cQ)(p,"level",f.bX)}});break;default:throw new Error(`Unsupported compressor: ${JSON.stringify(m)}`)}});const h=ul(u,{dataType:c,chunkShape:r});return{zarrVersion:2,nodeType:"array",rank:s,shape:n,chunkShape:r,dataType:c,fillValue:d,dimensionNames:(0,f.cQ)(e,"_ARRAY_DIMENSIONS",p=>(0,f.ZD)(p,s)),dimensionUnits:(0,f.cQ)(e,"dimension_units",p=>(0,f.ZD)(p,s)),userAttributes:e,dimensionSeparator:a,chunkKeyEncoding:hl.V2,codecs:h}}catch(n){throw new Error(`Error parsing zarr v2 metadata: ${n.message}`)}}/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var K0=(i=>(i[i.START=0]="START",i[i.END=1]="END",i))(K0||{});ss({name:"sharding_indexed",kind:_t.L.arrayToBytes,resolve(i,e){(0,f.Rf)(i);const t=(0,f.cQ)(i,"chunk_shape",l=>Hu(l,e.chunkShape.length)),n=(0,f.MM)(i,"index_location",l=>(0,f.sl)(l,K0,/^[a-z]+$/),1),s=Array.from(e.chunkShape,(l,c)=>{const d=t[c];if(l%d!==0)throw new Error(`sub-chunk shape of ${JSON.stringify(d)} does not evenly divide outer chunk shape of ${JSON.stringify(e.chunkShape)}`);return l/d}),r=Array.from(s);r.push(2);const o=(0,f.cQ)(i,"index_codecs",l=>ul(l,{dataType:R.UINT64,chunkShape:r}));if(o.encodedSize[o.encodedSize.length-1]===void 0)throw new Error("index_codecs must specify fixed-size encoding");const a=(0,f.cQ)(i,"codecs",l=>ul(l,{dataType:e.dataType,chunkShape:t}));return{configuration:{indexCodecs:o,subChunkCodecs:a,subChunkShape:t,subChunkGridShape:s,indexLocation:n},shardingInfo:{subChunkShape:t,subChunkGridShape:s,subChunkCodecs:a}}},getDecodedArrayLayoutInfo(i,e){return i.subChunkCodecs.layoutInfo[0]}});/** + * @license + * Copyright 2023 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ss({name:"transpose",kind:_t.L.arrayToArray,resolve(i,e){(0,f.Rf)(i);const{order:t,inverseOrder:n}=(0,f.cQ)(i,"order",r=>{const o=e.chunkShape.length,a=new Array(o),l=new Array(o);if(r==="C")for(let c=0;c{if(typeof c!="number"||!Number.isInteger(c)||c<0||c>=o)throw new Error(`Expected integer in range [0, ${o}) but received: ${JSON.stringify(c)}`);if(l[c]!==void 0)throw new Error(`Invalid permutation: ${JSON.stringify(r)}`);return l[c]=d,c});return{order:a,inverseOrder:l}}),s={dataType:e.dataType,chunkShape:Array.from(t,r=>e.chunkShape[r])};return{configuration:{encodedToDecoded:t,decodedToEncoded:n},encodedArrayInfo:s}},getDecodedArrayLayoutInfo(i,e,t){return{physicalToLogicalDimension:Array.from(t.physicalToLogicalDimension,s=>i.encodedToDecoded[s]),readChunkShape:Array.from(i.decodedToEncoded,s=>t.readChunkShape[s])}}});/** + * @license + * Copyright 2022 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const LN=new Set(["0.4","0.5-dev"]),q0=new Map([["angstrom",{unit:"m",scale:1e-10}],["foot",{unit:"m",scale:.3048}],["inch",{unit:"m",scale:.0254}],["mile",{unit:"m",scale:1609.34}],["parsec",{unit:"m",scale:0x6da012f95c9e88}],["yard",{unit:"m",scale:.9144}],["minute",{unit:"s",scale:60}],["hour",{unit:"s",scale:60*60}],["day",{unit:"s",scale:60*60*24}]]);for(const i of["meter","second"])for(const e of Bl){const{longPrefix:t}=e;t!==void 0&&q0.set(`${t}${i}`,{unit:i[0],scale:10**e.exponent})}function RN(i){(0,f.Rf)(i);const e=(0,f.cQ)(i,"name",f.zr),t=(0,f.MM)(i,"type",f.zr),n=(0,f.MM)(i,"unit",s=>{const r=q0.get(s);if(r===void 0)throw new Error(`Unsupported unit: ${JSON.stringify(s)}`);return r},{unit:"",scale:1});return{name:e,unit:n.unit,scale:n.scale,type:t}}function kN(i){const e=(0,f.$v)(i,RN);return Oe({names:e.map(t=>{const{name:n,type:s}=t;return s==="channel"?`${n}'`:n}),scales:Float64Array.from(e,t=>t.scale),units:e.map(t=>t.unit)})}function PN(i,e){const t=(0,f.cQ)(e,"scale",n=>(0,f.Xu)(new Float64Array(i),n,f.Mo));return De.nx(Float64Array,t)}function AN(i,e){return De.DA(Float64Array,i+1)}function MN(i,e){const t=(0,f.cQ)(e,"translation",n=>(0,f.Xu)(new Float64Array(i),n,f.zo));return De.u6(Float64Array,t)}const NN=new Map([["scale",PN],["identity",AN],["translation",MN]]);function ON(i,e){(0,f.Rf)(e);const t=(0,f.cQ)(e,"type",f.zr),n=NN.get(t);if(n===void 0)throw new Error(`Unsupported coordinate transform type: ${JSON.stringify(t)}`);return n(i,e)}function X0(i,e){let t=De.DA(Float64Array,i+1);return e===void 0||(0,f.$v)(e,n=>{const s=ON(i,n);t=De.lw(new Float64Array(t.length),i+1,s,i+1,t,i+1,i+1,i+1,i+1)}),t}function _N(i,e,t){const n=(0,f.cQ)(t,"path",f.zr),s=(0,f.cQ)(t,"coordinateTransformations",o=>X0(i,o));return{url:`${e}/${n}`,transform:s}}function VN(i,e){const t=(0,f.cQ)(e,"axes",kN),n=t.rank,s=(0,f.cQ)(e,"coordinateTransformations",l=>X0(n,l)),r=(0,f.cQ)(e,"datasets",l=>(0,f.$v)(l,c=>{const d=_N(n,i,c);return d.transform=De.lw(new Float64Array((n+1)**2),n+1,s,n+1,d.transform,n+1,n+1,n+1,n+1),d}));if(r.length===0)throw new Error("At least one scale must be specified");const o=r[0].transform,a=new Float64Array(n);for(let l=0;l{const{metadata:n}=t,{rank:s,codecs:r,shape:o}=n,a=r.layoutInfo[0].readChunkShape,{physicalToLogicalDimension:l}=n.codecs.layoutInfo[0],c=new Uint32Array(s),d=new Float32Array(s),u=new Float32Array((s+1)**2);u[(s+1)**2-1]=1;for(let p=0;p({chunkSource:this.chunkManager.getChunkSource(FN,{credentialsProvider:this.credentialsProvider,spec:p,parameters:{url:t.url,metadata:n}}),chunkToMultiscaleTransform:h}))}))}}function Yu(i,e,t){return i.memoize.getUncounted({type:"zarr:json",url:t,credentialsProvider:xt(e)},async()=>{try{return await Nt(e,t,{},ke.cj)}catch(n){if((0,ke.El)(n))return;throw n}})}const $N=[{key:{value:"dimension_separator",description:"Dimension separator in chunk keys"},values:[{value:".",description:"(default)"},{value:"/",description:""}]}];function GN(i,e){const t=new Set,n=e===2?"d":"dim_";return i.map((s,r)=>{if(s===null){let a=r;for(;;){if(s=`${n}${a}`,!t.has(s))return t.add(s),s;++a}}if(!t.has(s))return t.add(s),s;let o=1;for(;;){const a=`${s}${o}`;if(!t.has(a))return t.add(a),a;++o}})}function zN(i,e){const t=GN(e.dimensionNames,e.zarrVersion),n=e.dimensionUnits.map(TN),s=Oe({names:t,scales:Float64Array.from(Array.from(n,o=>o.scale)),units:Array.from(n,o=>o.unit),boundingBoxes:[En({lowerBounds:new Float64Array(e.rank),upperBounds:Float64Array.from(e.shape)})]}),r=De.DA(Float64Array,e.rank+1);return{coordinateSpace:s,dataType:e.dataType,scales:[{url:i,transform:r,metadata:e}]}}async function WN(i,e,t,n){const s=await Promise.all(t.scales.map(async g=>{const v=await pl(i,e,g.url,{zarrVersion:n.zarrVersion,expectedNodeType:"array",explicitDimensionSeparator:n.explicitDimensionSeparator});if(v===void 0)throw new Error(`zarr v{zarrVersion} array metadata not found at ${g.url}`);return v})),r=s[0].dataType,o=s.length,a=t.coordinateSpace.rank;for(let g=0;g{const y=s[v];return{url:g.url,transform:g.transform,metadata:y}})}}async function pl(i,e,t,n){if(n.zarrVersion===2){const[o,a]=await Promise.all([Yu(i,e,`${t}/.zarray`),Yu(i,e,`${t}/.zattrs`)]);return o===void 0?a===void 0||n.expectedNodeType==="array"?void 0:{zarrVersion:2,nodeType:"group",userAttributes:(0,f.Rf)(a)}:n.expectedNodeType==="group"?void 0:IN(o,a??{},n.explicitDimensionSeparator)}if(n.zarrVersion===3){const o=await Yu(i,e,`${t}/zarr.json`);if(o===void 0)return;if(n.explicitDimensionSeparator!==void 0)throw new Error("dimension_separator query parameter not supported for zarr v3");return DN(o,n.expectedNodeType)}const[s,r]=await Promise.all([pl(i,e,t,{...n,zarrVersion:2}),pl(i,e,t,{...n,zarrVersion:3})]);if(s!==void 0&&r!==void 0)throw new Error("Both zarr v2 and v3 metadata found");return s??r}class Qu extends Jt{constructor(e=void 0){super(),this.zarrVersion=e}get description(){return`Zarr${this.zarrVersion===void 0?"":` v${this.zarrVersion}`} data source`}get(e){let[,t,n]=e.providerUrl.match(/([^?]*)(?:\?(.*))?$/);const s=(0,f.bL)(n||"");(0,f.Rf)(s);const r=(0,f.MM)(s,"dimension_separator",Ju);return t.endsWith("/")&&(t=t.substring(0,t.length-1)),e.chunkManager.memoize.getUncounted({type:"zarr:MultiscaleVolumeChunkSource",providerUrl:t,dimensionSeparator:r},async()=>{const{url:o,credentialsProvider:a}=wn(t,e.credentialsManager),l=await pl(e.chunkManager,a,o,{zarrVersion:this.zarrVersion,explicitDimensionSeparator:r});if(l===void 0)throw new Error("No zarr metadata found");let c;if(l.nodeType==="group"){const u=BN(o,l.userAttributes);if(u===void 0)throw new Error("Neithre array nor OME multiscale metadata found");c=await WN(e.chunkManager,a,u,{zarrVersion:l.zarrVersion,explicitDimensionSeparator:r})}else c=zN(o,l);const d=new UN(e.chunkManager,a,c);return{modelTransform:wt(d.modelSpace),subsources:[{id:"default",default:!0,url:void 0,subsource:{volume:d}},{id:"bounds",default:!0,url:void 0,subsource:{staticAnnotations:xn(d.modelSpace.bounds)}}]}})}async completeUrl(e){const[,,t]=e.providerUrl.match(/([^?]*)(?:\?(.*))?$/);return t!==void 0?yi(e.providerUrl.length-t.length,await vg(t,$N)):await ts(e.credentialsManager,e.providerUrl,e.cancellationToken)}}/** + * @license + * Copyright 2020 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */Ot("zarr",()=>new Qu),Ot("zarr2",()=>new Qu(2)),Ot("zarr3",()=>new Qu(3));/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function HN(i){i.registerEventListener(document,"copy",e=>{if(xc(e.target))return;const t=document.getSelection();if(t!==null&&t.type==="Range")return;const n=Lo(i.state).value,{clipboardData:s}=e;s!==null&&s.setData("text/plain",JSON.stringify(n,void 0," ")),e.preventDefault()})}function JN(i,e){let t=String.raw`^[\[\]{}()\s,]*`;for(let r=0;r{if(xc(e.target))return;const{clipboardData:t}=e;if(t!==null){const n=t.getData("text/plain"),s=JN(n,i.coordinateSpace.value.rank);s!==void 0&&(i.navigationState.position.value=s)}e.preventDefault()})}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function YN(){return(0,T.K6)(document,"contextmenu",i=>{i.preventDefault()})}function QN(){return(0,T.K6)(document,"wheel",i=>{i.ctrlKey&&i.preventDefault()},{passive:!1})}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Z0=Symbol("SingleTextureVolumeChunk.textureUnit"),fl=Symbol("SingleTextureVolumeChunk.textureLayout");class eb extends T.O8{constructor(e,t){super(),this.shaderKey=e,this.dataType=t}defineShader(e,t){e.addTextureSampler(this.shaderSamplerType,"uVolumeChunkSampler",Z0)}beginDrawing(e,t){const n=t.textureUnit(Z0);e.activeTexture(WebGL2RenderingContext.TEXTURE0+n),t[fl]=null}endDrawing(e,t){e.bindTexture(cr[this.shaderSamplerType],null),t[fl]=null}bindChunk(e,t,n,s,r,o,a){const l=n.textureLayout;(t[fl]!==l||a)&&(t[fl]=l,this.setupTextureLayout(e,t,l,s,r,o)),e.bindTexture(cr[this.shaderSamplerType],n.texture)}beginSource(e,t){}}class tb extends zI{constructor(e,t){super(e,t),this.texture=null,this.data=t.data}copyToGPU(e){if(super.copyToGPU(e),this.data===null)return;const t=this.texture=e.createTexture(),n=cr[this.chunkFormat.shaderSamplerType];e.bindTexture(n,t),this.setTextureData(e),e.bindTexture(n,null)}freeGPUMemory(e){super.freeGPUMemory(e),this.data!==null&&(e.deleteTexture(this.texture),this.texture=null,this.textureLayout.dispose(),this.textureLayout=null)}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class gl extends T.O8{constructor(e,t,n){super(),this.chunkDataSize=t,this.textureDims=n,this.textureShape=new Uint32Array(this.textureDims);const s=t.length;let r=0;for(const u of t)u!==1&&++r;const o=this.strides=new Uint32Array(s*n),a=n===3?e.max3dTextureSize:e.maxTextureSize;let l=0,c=1;const{textureShape:d}=this;d.fill(1);for(let u=0;ua||c!==1&&l+rnew gl(e,t,n))}}let Ku=new Uint32Array(3*5);class qu extends eb{constructor(e,t,n,s){super(n,t),this.textureDims=s,Wi(this,t),this.shaderSamplerType=`${this.samplerPrefix}sampler${s}D`,this.textureAccessHelper=new wD("chunkData",s)}static get(e,t,n){const s=`sliceview.UncompressedChunkFormat:${t}:${n}`;return e.memoize.get(s,()=>new qu(e,t,s,n))}defineShader(e,t,n=!1){super.defineShader(e,t);const{textureDims:s}=this,r=`ivec${this.textureDims}`,{textureAccessHelper:o}=this,a=(4+t)*s;Ku.length=d))for(let g=0;g1&&++n;const s=n>=3?3:2;this.chunkFormat=this.registerDisposer(qu.get(e,t.dataType,s)),this.textureLayout=this.registerDisposer(this.chunkFormat.getTextureLayout(e,t.chunkDataSize)),this.fillValueChunk=this.registerDisposer(e.memoize.get(`sliceview.UncompressedChunkFormat.fillValue:${t.chunkDataSize.length}:${t.dataType}:${t.fillValue}:${s}`,()=>ZN(e,this.chunkFormat,t.fillValue,t.chunkDataSize.length,s)))}getChunk(e,t){const n=new KN(e,t);return n.data===null&&(n.texture=this.fillValueChunk.texture,n.textureLayout=this.fillValueChunk.textureLayout),n}}Dv((i,e)=>e.compressedSegmentationBlockSize==null?new eO(i,e):null);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function nb(i,e,t,n,s,r){let o=0,a=0,l=1,c=1;for(let g=0;g<3;++g){const v=s[g],y=n[g],S=Math.floor(v/y),w=v%y;o+=S*l,l*=Math.ceil(t[g]/y),a+=w*c,c*=y}const d=e+o*2,u=i[d],h=i[d+1];let p=u&16777215;const m=u>>24&255;if(m>0){const v=(e+h&16777215)+Math.floor(a*m/32),y=i[v],S=a*m%32,w=y>>S&(1<new ml(t,n))}}const iO=Wi(new Ns,R.UINT32);let Xu=new Uint32Array(4*4);class Zu extends eb{constructor(e,t,n,s){super(s,e),this.subchunkSize=t,this.numChannels=n,this.textureAccessHelper=new xa("chunkData")}static get(e,t,n,s){const r=`sliceview.CompressedSegmentationChunkFormat:${t}:${s}`,o=`${r}:${(0,C.nL)(n)}`;return e.memoize.get(o,()=>new Zu(t,n,s,r))}get shaderSamplerType(){return"usampler2D"}defineShader(e,t){super.defineShader(e,t);const n=4*(4+t);Xu.length"compressedSegmentationChunkFormat_"+c;e.addUniform("highp ivec3","uSubchunkGridSize"),e.addUniform("highp ivec3","uSubchunkSize"),e.addUniform("highp ivec4","uVolumeChunkStrides",4+t),e.addFragmentCode(kw);const{dataType:o}=this,a=yt(o);o===R.UINT64?e.addFragmentCode(gt):e.addFragmentCode(To),e.addFragmentCode(s.getAccessor(r("readTextureValue"),"uVolumeChunkSampler",R.UINT32,1));let l=` +uint ${r("getChannelOffset")}(int channelIndex) { + if (channelIndex == 0) { + return ${this.numChannels}u; + } + return ${r("readTextureValue")}(uint(channelIndex)).value; +} +${a} getDataValueAt(highp ivec3 p`;for(let c=0;c> 24u; + if (encodingBits > 0u) { + ivec3 subchunkPosition = chunkPosition - subchunkGridPosition * uSubchunkSize; + int subchunkOffset = getFortranOrderIndex(subchunkPosition, uSubchunkSize); + uint encodedValueBaseOffset = subchunkHeader1 + uint(channelOffset); + uint encodedValueOffset = encodedValueBaseOffset + uint(subchunkOffset) * encodingBits / 32u; + uint encodedValue = ${r("readTextureValue")}(encodedValueOffset).value; + uint wordOffset = uint(subchunkOffset) * encodingBits % 32u; + uint encodedValueShifted = encodedValue >> wordOffset; + uint decodedValue = encodedValueShifted - (encodedValueShifted >> encodingBits << encodingBits); + outputValueOffset += decodedValue * ${this.dataType===R.UINT64?"2u":"1u"}; + } + ${a} result; +`,o===R.UINT64?l+=` + result.value[0] = ${r("readTextureValue")}(outputValueOffset).value; + result.value[1] = ${r("readTextureValue")}(outputValueOffset+1u).value; +`:l+=` + result.value = ${r("readTextureValue")}(outputValueOffset).value; +`,l+=` + return result; +} +`,e.addFragmentCode(l)}setupTextureLayout(e,t,n,s,r,o){const{subchunkGridSize:a}=n;e.uniform3i(t.uniform("uSubchunkGridSize"),a[0],a[1],a[2]);const l=Xu,c=o.length;if(l.fill(0),!n.singleton){for(let d=0;d<3;++d){l[d]=s[d];const u=r[d];u!==-1&&(l[4*(d+1)+u]=1)}for(let d=0;doO(e,this.chunkFormat,t.fillValue)))}getChunk(e,t){const n=new sO(e,t);return n.data===null&&(n.texture=this.fillValueChunk.texture,n.textureLayout=this.fillValueChunk.textureLayout),n}}Dv((i,e)=>e.compressedSegmentationBlockSize!=null?new aO(i,e):null);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var rb=G(9783),lO=G(8085),cO=G(2027),dO=G(6984);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function dn(i,e){return t=>{t.style.flex=i,e(t)}}function S2(i,e){return t=>{Object.assign(t.style,i),e(t)}}function b2(i,e){return t=>{Object.assign(t,i),e(t)}}function rs(i,e){return t=>{t.style.display="flex",t.style.flexDirection=i;for(const n of e){const s=t.ownerDocument.createElement("div");t.appendChild(s),n(s)}}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const uO=C.pB.create();function ob(i,e){const t=C.pB.identity(uO),{globalPosition:n,displayDimensionRenderInfo:{canonicalVoxelFactors:s,displayDimensionIndices:r}}=i;for(let o=0;o<3;++o){const a=r[o];t[12+o]=a===-1?0:n[a],t[5*o]=e/s[o]}return C.pB.multiply(t,i.viewProjectionMat,t),t}class vl extends T.O8{constructor(e){super(),this.gl=e,this.vertexBuffer=this.registerDisposer(At.fromData(e,new Float32Array([0,0,0,1,1,0,0,1,0,0,0,1,0,1,0,1,0,0,0,1,0,0,1,1]),e.ARRAY_BUFFER,e.STATIC_DRAW));const t=.5;this.colorBuffer=this.registerDisposer(At.fromData(e,new Float32Array([1,0,0,t,1,0,0,t,0,1,0,t,0,1,0,t,0,0,1,t,0,0,1,t]),e.ARRAY_BUFFER,e.STATIC_DRAW)),this.trivialColorShader=this.registerDisposer(Sw(e))}static get(e){return e.memoize.get("SliceViewPanel:AxesLineHelper",()=>new vl(e))}draw(e,t=!0){const n=this.trivialColorShader,s=this.gl;n.bind(),s.uniformMatrix4fv(n.uniform("uProjectionMatrix"),!1,e);const r=n.attribute("aVertexPosition");this.vertexBuffer.bindToVertexAttrib(r,4);const o=n.attribute("aColor");this.colorBuffer.bindToVertexAttrib(o,4),t&&(s.colorMask(!1,!1,!1,!0),s.clearColor(0,0,0,0),s.clear(s.COLOR_BUFFER_BIT),s.colorMask(!0,!0,!0,!0),s.enable(s.BLEND),s.blendFunc(s.ONE_MINUS_DST_ALPHA,s.DST_ALPHA)),s.lineWidth(1),s.drawArrays(s.LINES,0,6),t&&s.disable(s.BLEND),s.disableVertexAttribArray(r),s.disableVertexAttribArray(o)}}var hO=G(4373);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const ab=!1;class lb{constructor(){this.renderLayers=[null],this.pickData=[null],this.values=[0,0,0],this.nextPickID=1}clear(){this.renderLayers.length=1,this.pickData.length=1,this.values.length=3,this.nextPickID=1}registerUint64(e,t,n=1,s=null){return this.register(e,n,t.low,t.high,s)}register(e,t=1,n=0,s=0,r=null){const{renderLayers:o,values:a}=this,l=this.nextPickID;this.nextPickID+=t;const c=o.length;o[c]=e;const d=c*3;return a[d]=l,a[d+1]=n,a[d+2]=s,this.pickData[c]=r,l}setMouseState(e,t){const{renderLayers:n,values:s}=this;let r=0,o=n.length-1;for(;rt?o=h-1:r=h}const a=e.pickedRenderLayer=n[r],l=r*3,c=e.pickedOffset=t-s[l];ab&&console.log(`Looking up pick ID ${t}: renderLayer`,a,`offset=${c}`);const{pickedValue:d}=e;d.low=s[l+1],d.high=s[l+2],e.pickedAnnotationId=void 0,e.pickedAnnotationLayer=void 0,e.pickedAnnotationBuffer=void 0,e.pickedAnnotationBufferBaseOffset=void 0,e.pickedAnnotationIndex=void 0,e.pickedAnnotationCount=void 0,e.pickedAnnotationType=void 0;const u=this.pickData[r];a!==null&&(ab&&console.log(`Picked value=${d}, offset=${c}, data=${this.pickData[r]}`),a.updateMouseState(e,d,c,u))}}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const cb=10,pO=1e3,fO=400,gO=500,mO=Math.PI/20,vO=20,yO=10;function db(i,e){return Math.sqrt(i*i+e*e)}function ub(i){let[e,t]=i;e.identifier>t.identifier&&([t,e]=[e,t]);const n=e.clientX-t.clientX,s=e.clientY-t.clientY,r=db(n,s),o=Math.atan2(n,s);return{distance:r,angle:o}}function SO(i,e){const t=Math.PI*2,n=Math.abs(i-e)%t;return Math.min(n,t-n)}class bO extends T.O8{constructor(e,t){super(),this.target=e,this.eventMap=t,this.prevTouches=new Map,this.moved=!1,this.prevAngle=0,this.rotated=!1,this.prevDistance=0,this.pinched=!1,this.prevCenterX=0,this.prevCenterY=0,this.translated=!1,this.startHold=this.registerCancellable((0,la.A)((n,s,r,o)=>{const a={event:n,centerX:r,centerY:o};this.dispatch(`touchhold${n.targetTouches.length}`,n,a,s)},pO,{leading:!1,trailing:!0})),this.numPriorTaps=0,this.priorTapNumTouches=0,this.tapStartTime=0,this.tapEndTime=0,this.curTapNumTouches=0,this.registerEventListener(e,"touchstart",n=>{this.handleTouchEvent(n)}),this.registerEventListener(e,"touchmove",n=>{this.handleTouchEvent(n)}),this.registerEventListener(e,"touchend",n=>{this.handleTouchEvent(n)})}dispatch(e,t,n,s=t.eventPhase){lf(e,t,s,n,this.eventMap)}handleTouchEvent(e){if(e.target===this.target)e.preventDefault();else return;const t=new Map,{prevTouches:n,prevEvent:s}=this;let r=0,o=0;for(const h of e.targetTouches)t.set(h.identifier,h),r+=h.clientX,o+=h.clientY;r/=t.size,o/=t.size;for(const[h,p]of n.entries()){const m=t.get(h);if(m===void 0)n.delete(h);else{const g=m.clientX-p.clientX,v=m.clientY-p.clientY;(Math.abs(g)>=cb||Math.abs(v)>=cb)&&(this.moved=!0)}}if(s===void 0||s.targetTouches.length!==t.size||t.size===0){if(this.moved=!1,e.type==="touchstart")this.startHold(e,e.eventPhase,r,o),(s===void 0||s.targetTouches.length===0)&&(this.tapStartTime=Date.now(),this.curTapNumTouches=0),this.curTapNumTouches=Math.max(this.curTapNumTouches,e.targetTouches.length);else{if(e.type==="touchend"){const h=Date.now();if(e.targetTouches.length===0&&h-this.tapStartTime=gO)&&(this.numPriorTaps=0),++this.numPriorTaps,this.tapEndTime=h,this.priorTapNumTouches=this.curTapNumTouches;const p={event:e,centerX:r,centerY:o};this.dispatch(`touchtap${this.curTapNumTouches}x${this.numPriorTaps}`,e,p)}}this.startHold.cancel()}if(this.prevTouches=t,this.prevEvent=e,this.prevCenterX=r,this.prevCenterY=o,this.translated=!1,t.size===2){const{distance:h,angle:p}=ub(t.values());this.prevDistance=h,this.prevAngle=p,this.rotated=!1,this.pinched=!1}return}if(!this.moved)return;this.tapStartTime=0,this.startHold.cancel(),this.prevTouches=t,this.prevEvent=e;let{prevCenterX:a,prevCenterY:l,translated:c}=this;const d=r-a,u=o-l;if(c===!1&&db(d,u)>=yO&&(c=this.translated=!0),c===!0&&(d!==0||u!==0)){this.prevCenterX=r,this.prevCenterY=o;const h={event:e,deltaX:d,deltaY:u,centerX:r,centerY:o};this.dispatch(`touchtranslate${t.size}`,e,h)}if(t.size===2){const{distance:h,angle:p}=ub(t.values());let{pinched:m,rotated:g,prevDistance:v,prevAngle:y}=this;m===!1&&Math.abs(h-v)>=vO&&(this.pinched=m=!0);const S=SO(p,y);if(g===!1&&S>=mO&&(this.rotated=g=!0),m===!0&&h!==v){this.prevDistance=h;const w={event:e,distance:h,prevDistance:v,centerX:r,centerY:o};this.dispatch("touchpinch",e,w)}g===!0&&p!==y&&(this.prevAngle=p,this.dispatch("touchrotate",e,{event:e,centerX:r,centerY:o,angle:p,prevAngle:y}))}}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const eh=C.eR.create();class hb{constructor(){this.pickIDs=new lb,this.viewportWidth=0,this.viewportHeight=0,this.invTransform=C.pB.create(),this.frameNumber=-1}}class pb{constructor(){this.buffer=null,this.glWindowX=0,this.glWindowY=0}}const CO=30,Et=5,je=1+Et*2,yl=(()=>{const i=Et**2,e=(s,r)=>(s-Et)**2+(r-Et)**2;let t=new Uint32Array(je*je),n=0;for(let s=0;si||(t[n++]=r*je+s);return t=t.subarray(0,n),t.sort((s,r)=>{const o=s%je,a=(s-o)/je,l=r%je,c=(r-l)/je;return e(o,a)-e(l,c)}),t})();function fb(i,e,t,n,s,r,o){const a=n-Et,l=s-Et;if(!(a>=0&&l>=0&&a+je<=r&&l+je<=o))for(let c=0;c=r||h>=o)&&(i[e+(h*je+u)*t]=0)}}class gb extends rp{constructor(e,t,n){super(e,t,n.visibility),this.viewer=n,this.mouseX=-1,this.mouseY=-1,this.pickRequestPending=!1,this.mouseStateForcer=()=>this.blockOnPickRequest(),this.isMovingToMousePosition=!1,this.pickingData=[new hb,new hb],this.pickRequests=[new pb,new pb],this.pickBufferContents=new Float32Array(8*je*je),this.pickTimerId=-1,this.nextPickRequestTime=0,this.pendingPickRequestTimerId=-1,this.pendingPickRequestTimerExpired=()=>{this.pendingPickRequestTimerId=-1,this.pickRequestPending&&this.attemptToIssuePickRequest()},this.isMovingToMousePositionOnPick=!1,this.inputEventMap=n.inputEventMap,t.classList.add("neuroglancer-rendered-data-panel"),t.classList.add("neuroglancer-panel"),t.classList.add("neuroglancer-noselect"),typeof NEUROGLANCER_SHOW_OBJECT_SELECTION_TOOLTIP<"u"&&NEUROGLANCER_SHOW_OBJECT_SELECTION_TOOLTIP===!0&&(t.title="Double click to toggle display of object under mouse pointer. Control+rightclick to pin/unpin selection."),this.registerDisposer(new za(t)),this.registerDisposer(new yn(t,this.inputEventMap)),this.registerDisposer(new tn(t,this.inputEventMap,s=>{this.onMousemove(s)})),this.registerDisposer(new bO(t,this.inputEventMap)),this.registerEventListener(t,"mousemove",this.onMousemove.bind(this)),this.registerEventListener(t,"touchstart",this.onTouchstart.bind(this)),this.registerEventListener(t,"mouseleave",()=>this.onMouseout()),this.registerEventListener(t,"mouseover",s=>{s.target!==t&&this.onMouseout()},!0),Z(t,"select-position",()=>{this.viewer.selectionDetailsState.select()}),Z(t,"snap",()=>{this.navigationState.pose.snap()}),Z(t,"zoom-in",()=>{this.context.flagContinuousCameraMotion(),this.navigationState.zoomBy(.5)}),Z(t,"zoom-out",()=>{this.context.flagContinuousCameraMotion(),this.navigationState.zoomBy(2)}),Z(t,"depth-range-decrease",()=>{this.context.flagContinuousCameraMotion(),this.navigationState.depthRange.value*=.5}),Z(t,"depth-range-increase",()=>{this.context.flagContinuousCameraMotion(),this.navigationState.depthRange.value*=2});for(let s=0;s<3;++s){const r=C.p9[s];for(const o of[-1,1]){const a=o<0?"-":"+";Z(t,`rotate-relative-${r}${a}`,()=>{this.context.flagContinuousCameraMotion(),this.navigationState.pose.rotateRelative(C.T2[s],o*.1)});const l=C.eR.create();Z(t,`${r}${a}`,()=>{this.context.flagContinuousCameraMotion();const{navigationState:c}=this,d=l;d[0]=0,d[1]=0,d[2]=0,d[s]=o,c.pose.translateVoxelsRelative(d)})}}Z(t,"zoom-via-wheel",s=>{this.context.flagContinuousCameraMotion();const r=s.detail;this.onMousemove(r,!1),this.zoomByMouse(_i(r))}),Z(t,"adjust-depth-range-via-wheel",s=>{this.context.flagContinuousCameraMotion();const r=s.detail;this.navigationState.depthRange.value*=_i(r)}),Z(t,"translate-via-mouse-drag",s=>{zt(s.detail,(r,o,a)=>{this.context.flagContinuousCameraMotion(),this.translateByViewportPixels(o,a)})}),Z(t,"translate-in-plane-via-touchtranslate",s=>{this.context.flagContinuousCameraMotion();const{detail:r}=s;this.translateByViewportPixels(r.deltaX,r.deltaY)}),Z(t,"translate-z-via-touchtranslate",s=>{this.context.flagContinuousCameraMotion();const{detail:r}=s,{navigationState:o}=this,a=eh;a[0]=0,a[1]=0,a[2]=r.deltaY+r.deltaX,o.pose.translateVoxelsRelative(a)});for(const s of[1,10])Z(t,`z+${s}-via-wheel`,r=>{this.context.flagContinuousCameraMotion();const o=r.detail,{navigationState:a}=this,l=eh,c=o.deltaY!==0?o.deltaY:o.deltaX;l[0]=0,l[1]=0,l[2]=(c>0?-1:1)*s,a.pose.translateVoxelsRelative(l)});Z(t,"move-to-mouse-position",()=>{const{mouseState:s}=this.viewer;s.updateUnconditionally()&&(this.navigationState.position.value=s.position)}),Z(t,"snap",()=>this.navigationState.pose.snap()),Z(t,"move-annotation",s=>{const{mouseState:r}=this.viewer,o=r.pickedAnnotationId,a=r.pickedAnnotationLayer;if(a!==void 0&&o!==void 0){s.stopPropagation();const l=a.source.getReference(o),c=l.value,d=Tr(c.type),u=r.pickedOffset,{chunkTransform:{value:h}}=a;if(h.error!==void 0)return;const{layerRank:p}=h,m=new Float32Array(p);d.getRepresentativePoint(m,c,r.pickedOffset);const g=C.Zc.set(C.Zc.create(),0,0);r.updateUnconditionally()&&zt(s.detail,(v,y,S)=>{C.Zc.add(g,g,[y,S]);const w=new Float32Array(p);De.vo(w,h.chunkToLayerTransform,p+1,m,p);const b=eh,{displayDimensionIndices:x}=this.navigationState.pose.displayDimensions.value;_C(b,w,h.modelTransform,x),this.translateDataPointByViewportPixels(b,b,g[0],g[1]),VC(w,b,h.modelTransform,x);const E=new Float32Array(p);De.vo(E,h.layerToChunkTransform,p+1,w,p);const D=d.updateViaRepresentativePoint(c,E,u);a.source.update(l,D)},v=>{a.source.commit(l),l.dispose()})}}),Z(t,"delete-annotation",()=>{const{mouseState:s}=this.viewer,r=s.pickedAnnotationId,o=s.pickedAnnotationLayer;if(o!==void 0&&!o.source.readonly&&r!==void 0){const a=o.source.getReference(r);try{o.source.delete(a)}finally{a.dispose()}}}),Z(t,"zoom-via-touchpinch",s=>{this.context.flagContinuousCameraMotion();const{detail:r}=s;this.handleMouseMove(r.centerX,r.centerY);const o=r.prevDistance/r.distance;o>.1&&o<10&&this.zoomByMouse(o)})}cancelPickRequests(){const{gl:e}=this;for(const t of this.pickRequests){const{sync:n}=t;n!==null&&e.deleteSync(n),t.sync=null}clearTimeout(this.pickTimerId),this.pickTimerId=-1}issuePickRequestInternal(e){const{gl:t}=this;let{buffer:n}=e;n===null?(n=e.buffer=t.createBuffer(),t.bindBuffer(WebGL2RenderingContext.PIXEL_PACK_BUFFER,n),t.bufferData(WebGL2RenderingContext.PIXEL_PACK_BUFFER,32*je*je,WebGL2RenderingContext.STREAM_READ)):t.bindBuffer(WebGL2RenderingContext.PIXEL_PACK_BUFFER,n);const{renderViewport:s}=this,r=this.mouseX-s.visibleLeftFraction*s.logicalWidth,o=s.height-(this.mouseY-s.visibleTopFraction*s.logicalHeight);this.issuePickRequest(r,o),e.sync=t.fenceSync(WebGL2RenderingContext.SYNC_GPU_COMMANDS_COMPLETE,0),e.frameNumber=this.context.frameNumber,e.glWindowX=r,e.glWindowY=o,t.flush(),t.bindBuffer(WebGL2RenderingContext.PIXEL_PACK_BUFFER,null),this.pickTimerId===-1&&this.scheduleCheckForPickRequestCompletion(),this.pickRequestPending=!1;const{pickRequests:a}=this;e!==a[0]&&(a[1]=a[0],a[0]=e),this.nextPickRequestTime=Date.now()+CO}completePickInternal(e){const{gl:t}=this,{pickBufferContents:n}=this;t.bindBuffer(WebGL2RenderingContext.PIXEL_PACK_BUFFER,e.buffer),t.getBufferSubData(WebGL2RenderingContext.PIXEL_PACK_BUFFER,0,n),t.bindBuffer(WebGL2RenderingContext.PIXEL_PACK_BUFFER,null);const{pickingData:s}=this,{frameNumber:r}=e;this.completePickRequest(e.glWindowX,e.glWindowY,n,s[0].frameNumber===r?s[0]:s[1])}scheduleCheckForPickRequestCompletion(){this.pickTimerId=window.setTimeout(()=>{this.pickTimerId=-1,this.checkForPickRequestCompletion()},0)}checkForPickRequestCompletion(e=!1,t=!1){let n=this.context.frameNumber,s=-1;e&&(--n,s=n-1);const{pickRequests:r}=this,{gl:o}=this;let a=!1,l=!1,c;for(const u of r){const{sync:h}=u;if(h===null)continue;const{frameNumber:p}=u;if(!l&&p>=n-1){if(t||o.getSyncParameter(h,WebGL2RenderingContext.SYNC_STATUS)===WebGL2RenderingContext.SIGNALED)this.completePickInternal(u),l=!0;else if(p!==s){a=!0;continue}}o.deleteSync(h),u.sync=null,c=u}const{pickTimerId:d}=this;a&&d===-1?this.scheduleCheckForPickRequestCompletion():!a&&d!==-1&&(window.clearTimeout(d),this.pickTimerId=-1),!e&&c!==void 0&&this.pickRequestPending&&this.canIssuePickRequest()&&this.issuePickRequestInternal(c)}blockOnPickRequest(){this.pickRequestPending&&(this.cancelPickRequests(),this.nextPickRequestTime=0,this.attemptToIssuePickRequest()),this.checkForPickRequestCompletion(!1,!0)}draw(){const{width:e,height:t}=this.renderViewport;this.checkForPickRequestCompletion(!0);const{pickingData:n}=this;n[0]=n[1];const s=this.context.frameNumber,r=n[1];if(r.frameNumber=s,r.viewportWidth=e,r.viewportHeight=t,r.pickIDs.clear(),!this.drawWithPicking(r)){r.frameNumber=-1;return}this.nextPickRequestTime=0,this.mouseX>=0&&this.attemptToIssuePickRequest()}canIssuePickRequest(){const e=Date.now(),{nextPickRequestTime:t,pendingPickRequestTimerId:n}=this;return e=s.lengthInNanometers){t=s;break}}return t}function w2(i){const e=Xs.length;let t=Xs[e-1];for(let n=0;n=s.lengthInNanometers**3){t=s;break}}return t}class xO{constructor(){this.allowedSignificands=wO,this.targetLengthInPixels=0,this.physicalSizePerPixel=0,this.prevPhysicalSizePerPixel=0,this.prevTargetLengthInPixels=0,this.prevPhysicalUnit="\0"}update(){const{physicalSizePerPixel:e,targetLengthInPixels:t}=this;if(this.prevPhysicalSizePerPixel===e&&this.prevTargetLengthInPixels===t&&this.prevPhysicalUnit===this.physicalUnit)return!1;this.prevPhysicalSizePerPixel=e,this.prevTargetLengthInPixels=t,this.prevPhysicalUnit=this.physicalUnit;const n=t*e,s=Math.floor(Math.log10(n)),r=10**s,o=n/r;let a=1;for(const d of this.allowedSignificands)if(Math.abs(d-o)=0;--w){const b=o[w];g===1?b.label="":b.label+=": ",b.update(r),v.viewport(r.leftPixelOffset*r.scaleFactor-e.visibleLeftFraction*e.logicalWidth,S-(1-(e.visibleTopFraction+e.visibleHeightFraction))*e.logicalHeight,b.width,b.height),y.draw(b.texture),S+=b.height+r.marginPixelsBetweenScaleBars*r.scaleFactor}}}const vb={...{scaleFactor:1,textHeightInPixels:15,barHeightInPixels:8,barTopMarginInPixels:5,fontName:"sans-serif",paddingInPixels:2},maxWidthInPixels:100,maxWidthFraction:.25,leftPixelOffset:10,bottomPixelOffset:10,marginPixelsBetweenScaleBars:5};function DO(i){const e={...vb};for(const t of["textHeightInPixels","barTopMarginInPixels","barHeightInPixels","paddingInPixels","scaleFactor","maxWidthInPixels","maxWidthFraction","leftPixelOffset","bottomPixelOffset"])(0,f.cQ)(i,t,n=>{n!==void 0&&(e[t]=(0,f._D)(n))});return(0,f.cQ)(i,"fontName",t=>{t!==void 0&&(e.fontName=(0,f.zr)(t))}),e}class IO extends _.DN{constructor(){super(vb,DO)}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var LO=(i=>(i[i.COLOR=0]="COLOR",i[i.Z=1]="Z",i[i.PICK=2]="PICK",i[i.NUM_TEXTURES=3]="NUM_TEXTURES",i))(LO||{}),RO=(i=>(i[i.TRANSPARENT=0]="TRANSPARENT",i[i.VOLUME_RENDERING=1]="VOLUME_RENDERING",i[i.MAX_PROJECTION=2]="MAX_PROJECTION",i))(RO||{});const kO=` +void emit(vec4 color, highp uint pickId) { + out_color = color; + float zValue = 1.0 - gl_FragCoord.z; + out_z = vec4(zValue, zValue, zValue, 1.0); + float pickIdFloat = float(pickId); + out_pickId = vec4(pickIdFloat, pickIdFloat, pickIdFloat, 1.0); +} +`,th=[` +float computeOITWeight(float alpha, float depth) { + float a = min(1.0, alpha) * 8.0 + 0.01; + float b = -depth * 0.95 + 1.0; + return a * a * a * b * b * b; +} +`,` +void emitAccumAndRevealage(vec4 accum, float revealage, highp uint pickId) { + v4f_fragData0 = vec4(accum.rgb, revealage); + v4f_fragData1 = vec4(accum.a, 0.0, 0.0, 0.0); +} +void emit(vec4 color, highp uint pickId) { + float weight = computeOITWeight(color.a, gl_FragCoord.z); + vec4 accum = color * weight; + emitAccumAndRevealage(accum, color.a, pickId); +} +`];function nh(i){i.addOutputBuffer("vec4","out_color",0),i.addOutputBuffer("highp vec4","out_z",1),i.addOutputBuffer("highp vec4","out_pickId",2),i.addFragmentCode(kO)}function ih(i){i.addOutputBuffer("vec4","v4f_fragData0",0),i.addOutputBuffer("vec4","v4f_fragData1",1),i.addFragmentCode(th)}function sh(i){i.addOutputBuffer("vec4","out_color",0),i.addOutputBuffer("highp vec4","out_z",1),i.addOutputBuffer("highp vec4","out_intensity",2),i.addOutputBuffer("highp vec4","out_pickId",3),i.addFragmentCode(` +void emit(vec4 color, float depth, float intensity, highp uint pickId) { + float pickIdFloat = float(pickId); + float bufferDepth = 1.0 - depth; + out_color = color; + out_z = vec4(bufferDepth, bufferDepth, bufferDepth, 1.0); + out_intensity = vec4(intensity, intensity, intensity, 1.0); + out_pickId = vec4(pickIdFloat, pickIdFloat, pickIdFloat, 1.0); +}`)}const ti=C.eR.create(),yb=C.ln.create(),PO=C.pB.create();function AO(i){i.addOutputBuffer("vec4","v4f_fragColor",null),i.setFragmentMain(` +vec4 v0 = getValue0(); +vec4 v1 = getValue1(); +vec4 accum = vec4(v0.rgb, v1.r); +float revealage = v0.a; + +v4f_fragColor = vec4(accum.rgb / accum.a, revealage); +`)}function MO(i){i.addOutputBuffer("vec4","v4f_fragData0",0),i.addOutputBuffer("vec4","v4f_fragData1",1),i.addFragmentCode(th),i.setFragmentMain(` +vec4 v0 = getValue0(); +vec4 v1 = getValue1(); +vec4 accum = vec4(v0.rgb, v1.r); +float revealage = v0.a; + +emitAccumAndRevealage(accum, 1.0 - revealage, 0u); +`)}function NO(i){i.addOutputBuffer("vec4","v4f_fragData0",0),i.addOutputBuffer("vec4","v4f_fragData1",1),i.addFragmentCode(th),i.setFragmentMain(` +vec4 color = getValue0(); +float bufferDepth = getValue1().r; +float weight = computeOITWeight(color.a, 1.0 - bufferDepth); +vec4 accum = color * weight; +float revealage = color.a; + +emitAccumAndRevealage(accum, revealage, 0u); +`)}function OO(i){i.addOutputBuffer("vec4","out_color",0),i.addOutputBuffer("highp vec4","out_z",1),i.addOutputBuffer("highp vec4","out_pickId",2),i.setFragmentMain(` +out_color = vec4(0.0); +out_z = getValue0(); +out_pickId = getValue1(); +`)}function _O(i){i.addOutputBuffer("highp vec4","out_z",0),i.addOutputBuffer("highp vec4","out_pickId",1),i.setFragmentMain(` +out_z = getValue0(); +out_pickId = getValue2(); +gl_FragDepth = getValue1().r; +`)}const VO=ar(hn);class BO extends VO{constructor(e){super(),this.panel=e}initializeCounterpart(e,t){this.sharedProjectionParameters=this.registerDisposer(new So(e,this.panel.projectionParameters)),t.projectionParameters=this.sharedProjectionParameters.rpcId,super.initializeCounterpart(e,t)}}class rh extends gb{constructor(e,t,n){super(e,t,n),this.hasVolumeRendering=!1,this.frameRateCalculator=new HC(6,8,8,60),this.isContinuousCameraMotionInProgress=!1,this.sliceViews=this.registerDisposer(new rc((r,o,a)=>{r.registerDisposer(a),r.registerDisposer(a.visibility.add(this.visibility))})),this.axesLineHelper=this.registerDisposer(vl.get(this.gl)),this.sliceViewRenderHelper=this.registerDisposer(ia.get(this.gl,nh)),this.offscreenFramebuffer=this.registerDisposer(new $n(this.gl,{colorBuffers:[new gn(this.gl,WebGL2RenderingContext.RGBA8,WebGL2RenderingContext.RGBA,WebGL2RenderingContext.UNSIGNED_BYTE),new gn(this.gl,WebGL2RenderingContext.R32F,WebGL2RenderingContext.RED,WebGL2RenderingContext.FLOAT),new gn(this.gl,WebGL2RenderingContext.R32F,WebGL2RenderingContext.RED,WebGL2RenderingContext.FLOAT)],depthBuffer:new xo(this.gl)})),this.offscreenCopyHelper=this.registerDisposer(Dn.get(this.gl)),this.transparencyCopyHelper=this.registerDisposer(Dn.get(this.gl,AO,2)),this.transparentToTransparentCopyHelper=this.registerDisposer(Dn.get(this.gl,MO,2)),this.maxProjectionColorCopyHelper=this.registerDisposer(Dn.get(this.gl,NO,2)),this.maxProjectionPickCopyHelper=this.registerDisposer(Dn.get(this.gl,OO,2)),this.maxProjectionToPickCopyHelper=this.registerDisposer(Dn.get(this.gl,_O,3)),this.scaleBars=this.registerDisposer(new mb(this.gl)),this.projectionParameters=this.registerDisposer(new yp({navigationState:this.navigationState,update:(r,o)=>{const{invViewMatrix:a,projectionMat:l,logicalWidth:c,logicalHeight:d}=r,u=c/d,h=Math.PI/4;let{relativeDepthRange:p}=o,g=o.zoomFactor.value/2;if(this.viewer.orthographicProjection.value){const v=Math.max(.1,1-p),y=1+p;C.pB.ortho(l,-u,u,-1,1,v,y)}else{const v=1/Math.tan(h/2);p/=v;const y=Math.max(.1,1-p),S=1+p;g*=v,C.pB.perspective(l,h,u,y,S)}ip(r,l),o.pose.toMat4(a,g),C.pB.scale(a,a,C.eR.set(ti,1,-1,-1)),C.pB.translate(a,a,C.T2[2]),ap(r)}})),this.projectionParameters.changed.add(()=>this.context.scheduleRedraw());const s=this.sharedObject=this.registerDisposer(new BO(this));if(s.RPC_TYPE_ID=hO.l,s.initializeCounterpart(n.rpc,{}),s.visibility.add(this.visibility),this.visibleLayerTracker=_g(this.viewer.layerManager,Gi,this.viewer.visibleLayerRoles,this),this.registerDisposer(this.context.continuousCameraMotionFinished.add(()=>{this.isContinuousCameraMotionInProgress=!1,this.hasVolumeRendering&&(this.scheduleRedraw(),this.frameRateCalculator.resetForNewFrameSet())})),this.registerDisposer(this.context.continuousCameraMotionStarted.add(()=>{this.isContinuousCameraMotionInProgress=!0})),Z(t,"rotate-via-mouse-drag",r=>{zt(r.detail,(o,a,l)=>{this.context.flagContinuousCameraMotion(),this.navigationState.pose.rotateRelative(C.T2[1],a/4*Math.PI/180),this.navigationState.pose.rotateRelative(C.T2[0],-l/4*Math.PI/180)})}),Z(t,"rotate-in-plane-via-touchrotate",r=>{this.context.flagContinuousCameraMotion();const{detail:o}=r;this.navigationState.pose.rotateRelative(C.T2[2],o.angle-o.prevAngle)}),Z(t,"rotate-out-of-plane-via-touchtranslate",r=>{this.context.flagContinuousCameraMotion();const{detail:o}=r;this.navigationState.pose.rotateRelative(C.T2[1],o.deltaX/4*Math.PI/180),this.navigationState.pose.rotateRelative(C.T2[0],-o.deltaY/4*Math.PI/180)}),n.showSliceViewsCheckbox){const r=this.registerDisposer(new pn(n.showSliceViews));r.element.className="perspective-panel-show-slice-views neuroglancer-noselect";const o=document.createElement("label");o.className="perspective-panel-show-slice-views neuroglancer-noselect",o.appendChild(document.createTextNode("Sections")),o.appendChild(r.element),this.element.appendChild(o)}this.registerDisposer(n.orthographicProjection.changed.add(()=>{this.projectionParameters.update(),this.scheduleRedraw()})),this.registerDisposer(n.showScaleBar.changed.add(()=>this.scheduleRedraw())),this.registerDisposer(n.scaleBarOptions.changed.add(()=>this.scheduleRedraw())),this.registerDisposer(n.showSliceViews.changed.add(()=>this.scheduleRedraw())),this.registerDisposer(n.showAxisLines.changed.add(()=>this.scheduleRedraw())),this.registerDisposer(n.crossSectionBackgroundColor.changed.add(()=>this.scheduleRedraw())),this.registerDisposer(n.perspectiveViewBackgroundColor.changed.add(()=>this.scheduleRedraw())),this.registerDisposer(n.wireFrame.changed.add(()=>this.scheduleRedraw())),this.sliceViews.changed.add(()=>this.scheduleRedraw())}get rpc(){return this.sharedObject.rpc}get rpcId(){return this.sharedObject.rpcId}get displayDimensionRenderInfo(){return this.navigationState.displayDimensionRenderInfo}get shouldDownsample(){return this.viewer.enableAdaptiveDownsampling.value&&this.isContinuousCameraMotionInProgress&&this.hasVolumeRendering}flushBackendProjectionParameters(){this.sharedObject.sharedProjectionParameters.flush()}translateByViewportPixels(e,t){const n=ti,{viewProjectionMat:s,invViewProjectionMat:r,logicalWidth:o,logicalHeight:a}=this.projectionParameters.value,{pose:l}=this.viewer.navigationState;l.updateDisplayPosition(c=>{C.eR.transformMat4(n,c,s),n[0]+=-2*e/o,n[1]+=2*t/a,C.eR.transformMat4(c,n,r)})}get navigationState(){return this.viewer.navigationState}ensureBoundsUpdated(){super.ensureBoundsUpdated(),this.projectionParameters.setViewport(this.renderViewport)}isReady(){if(!this.visible)return!0;for(const[o,a]of this.sliceViews)if((a||this.viewer.showSliceViews.value)&&!o.isReady())return!1;this.ensureBoundsUpdated();const{width:e,height:t}=this.renderViewport;if(e===0||t===0)return!0;const s={projectionParameters:this.projectionParameters.value},{visibleLayers:r}=this.visibleLayerTracker;for(const[o,a]of r)if(!o.isReady(s,a))return!1;return!0}disposed(){this.sliceViews.clear(),super.disposed()}getDepthArray(){if(!this.navigationState.valid)return;const{offscreenFramebuffer:e,renderViewport:{width:t,height:n}}=this,s=t*n,r=new Float32Array(s*4);try{e.bindSingle(1),this.gl.readPixels(0,0,t,n,WebGL2RenderingContext.RGBA,WebGL2RenderingContext.FLOAT,r)}finally{e.framebuffer.unbind()}const o=new Float32Array(s);for(let a=0;a{r.drawBuffers(this.offscreenFramebuffer.singleAttachmentList)},a=()=>{this.offscreenFramebuffer.bind(t,n)};a(),r.disable(r.SCISSOR_TEST),r.enable(WebGL2RenderingContext.STENCIL_TEST),r.stencilMask(4294967295),r.clearStencil(0),r.clear(WebGL2RenderingContext.STENCIL_BUFFER_BIT),r.stencilOp(WebGL2RenderingContext.KEEP,WebGL2RenderingContext.KEEP,WebGL2RenderingContext.REPLACE),r.stencilFunc(WebGL2RenderingContext.ALWAYS,1,1);const l=this.viewer.perspectiveViewBackgroundColor.value;this.gl.clearColor(l[0],l[1],l[2],0),r.clear(r.DEPTH_BUFFER_BIT),r.clearBufferfv(WebGL2RenderingContext.COLOR,0,[l[0],l[1],l[2],0]),r.clearBufferfv(WebGL2RenderingContext.COLOR,1,C.yb),r.clearBufferfv(WebGL2RenderingContext.COLOR,2,C.yb),r.enable(r.DEPTH_TEST);const c=this.projectionParameters.value,d=C.eR.create();C.eR.transformQuat(d,C.T2[2],this.navigationState.pose.orientation.orientation),C.eR.scale(d,d,-1);const u=.2,h=1-u,p={wireFrame:this.viewer.wireFrame.value,projectionParameters:c,lightDirection:d,ambientLighting:u,directionalLighting:h,pickIDs:e.pickIDs,emitter:nh,emitColor:!0,emitPickID:!0,alreadyEmittedPickID:!1,bindFramebuffer:a,frameNumber:this.context.frameNumber,sliceViewsPresent:this.sliceViews.size>0,isContinuousCameraMotionInProgress:this.isContinuousCameraMotionInProgress};C.pB.copy(e.invTransform,c.invViewProjectionMat);const{visibleLayers:m}=this.visibleLayerTracker;let g=!1,v=!1,y=!1,S=!1;for(const[w,b]of m)w.isTransparent?(g=!0,w.isVolumeRendering&&(S=!0,v=v||!this.isContinuousCameraMotionInProgress||dS(w))):w.isAnnotation?y=!0:w.draw(p,b);if(this.hasVolumeRendering=S,this.drawSliceViews(p),y){r.enable(WebGL2RenderingContext.BLEND),r.depthFunc(WebGL2RenderingContext.LEQUAL),r.blendFunc(WebGL2RenderingContext.SRC_ALPHA,WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA);for(const[w,b]of m)if(w.isAnnotation){const x=w;x.base.state.displayState.disablePicking.value?(o(),x.draw(p,b),p.bindFramebuffer()):x.draw(p,b)}r.depthFunc(WebGL2RenderingContext.LESS),r.disable(WebGL2RenderingContext.BLEND)}if(this.viewer.showAxisLines.value&&this.drawAxisLines(),r.stencilOp(WebGL2RenderingContext.KEEP,WebGL2RenderingContext.KEEP,WebGL2RenderingContext.KEEP),g){let w=t,b=n;if(this.shouldDownsample){this.frameRateCalculator.setFrameDeltas(this.context.getLastFrameTimesInMs(this.frameRateCalculator.numberOfStoredFrameDeltas));const N=this.frameRateCalculator.calculateDownsamplingRate(np.MEAN);if(N>1){const k=t/n;w=Math.round(t/N),b=Math.round(w/k)}}let x=()=>{},E=()=>{},D=()=>{};if(this.hasVolumeRendering){p.maxProjectionEmit=sh;const{maxProjectionConfiguration:N}=this;x=()=>{N.bind(w,b)},r.depthMask(!0),x(),p.bindMaxProjectionBuffer=x,r.clearColor(0,0,0,0),r.clearDepth(0),r.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT|WebGL2RenderingContext.DEPTH_BUFFER_BIT);const{maxProjectionPickConfiguration:k}=this;E=()=>{k.bind(w,b)},E(),r.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT|WebGL2RenderingContext.DEPTH_BUFFER_BIT),D=()=>{this.volumeRenderingConfiguration.bind(w,b)},D(),p.bindVolumeRenderingBuffer=D,r.clearDepth(1),r.clearColor(0,0,0,1),r.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT|WebGL2RenderingContext.DEPTH_BUFFER_BIT)}const{transparentConfiguration:I}=this;p.bindFramebuffer=()=>{I.bind(t,n)},p.bindFramebuffer(),r.depthMask(!1),r.enable(WebGL2RenderingContext.BLEND),r.clearColor(0,0,0,1),r.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT),p.emitter=ih,r.blendFuncSeparate(WebGL2RenderingContext.ONE,WebGL2RenderingContext.ONE,WebGL2RenderingContext.ZERO,WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA),p.emitPickID=!1;let L=0;for(const[N,k]of m)if(N.isVolumeRendering){p.depthBufferTexture=this.offscreenFramebuffer.colorBuffers[1].texture;const O=dS(N),V=!O&&!this.isContinuousCameraMotionInProgress&&!p.wireFrame;if(O?(r.depthMask(!0),r.disable(WebGL2RenderingContext.BLEND),r.depthFunc(WebGL2RenderingContext.GREATER),L!==2&&(p.emitter=sh,x())):(L!==1&&(p.emitter=ih,D()),r.disable(WebGL2RenderingContext.DEPTH_TEST),L=1),N.draw(p,k),r.enable(WebGL2RenderingContext.DEPTH_TEST),!V&&!O)continue;E(),this.maxProjectionToPickCopyHelper.draw(this.maxProjectionConfiguration.colorBuffers[1].texture,this.maxProjectionConfiguration.colorBuffers[2].texture,this.maxProjectionConfiguration.colorBuffers[3].texture),r.enable(WebGL2RenderingContext.BLEND),r.blendFuncSeparate(WebGL2RenderingContext.ONE,WebGL2RenderingContext.ONE,WebGL2RenderingContext.ZERO,WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA),O&&(D(),r.depthMask(!1),r.disable(WebGL2RenderingContext.DEPTH_TEST),this.maxProjectionColorCopyHelper.draw(this.maxProjectionConfiguration.colorBuffers[0].texture,this.maxProjectionConfiguration.colorBuffers[1].texture)),x(),p.emitter=sh,r.depthMask(!0),r.clearColor(0,0,0,0),r.clearDepth(0),r.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT|WebGL2RenderingContext.DEPTH_BUFFER_BIT),r.clearDepth(1),r.clearColor(0,0,0,1),r.depthMask(!1),r.enable(WebGL2RenderingContext.DEPTH_TEST),r.depthFunc(WebGL2RenderingContext.LESS),L=2}else N.isTransparent&&(L!==0&&(p.emitter=ih,p.bindFramebuffer()),L=0,N.draw(p,k));r.disable(WebGL2RenderingContext.DEPTH_TEST),S&&(p.bindFramebuffer(),this.transparentToTransparentCopyHelper.draw(this.volumeRenderingConfiguration.colorBuffers[0].texture,this.volumeRenderingConfiguration.colorBuffers[1].texture)),r.blendFunc(WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA,WebGL2RenderingContext.SRC_ALPHA),this.offscreenFramebuffer.bindSingle(0),this.transparencyCopyHelper.draw(I.colorBuffers[0].texture,I.colorBuffers[1].texture),r.depthMask(!0),r.disable(WebGL2RenderingContext.BLEND),r.enable(WebGL2RenderingContext.DEPTH_TEST),p.bindFramebuffer=a,a(),r.enable(WebGL2RenderingContext.STENCIL_TEST),r.drawBuffers([r.NONE,r.COLOR_ATTACHMENT1,r.COLOR_ATTACHMENT2]),p.emitter=nh,p.emitPickID=!0,p.emitColor=!1,r.stencilFunc(WebGL2RenderingContext.NOTEQUAL,3,1),r.stencilOp(WebGL2RenderingContext.KEEP,WebGL2RenderingContext.KEEP,WebGL2RenderingContext.REPLACE),r.stencilMask(2),v&&this.maxProjectionPickCopyHelper.draw(this.maxProjectionPickConfiguration.colorBuffers[0].texture,this.maxProjectionPickConfiguration.colorBuffers[1].texture);for(const[N,k]of m)!N.isTransparent||!N.transparentPickEnabled||N.isVolumeRendering||N.draw(p,k);r.stencilFunc(WebGL2RenderingContext.EQUAL,0,3),r.stencilOp(WebGL2RenderingContext.KEEP,WebGL2RenderingContext.KEEP,WebGL2RenderingContext.KEEP),r.stencilMask(0);for(const[N,k]of m)!N.isTransparent||N.transparentPickEnabled||N.draw(p,k)}if(r.stencilMask(4294967295),r.disable(WebGL2RenderingContext.STENCIL_TEST),this.viewer.showScaleBar.value&&this.viewer.orthographicProjection.value){r.drawBuffers([r.COLOR_ATTACHMENT0]),r.disable(WebGL2RenderingContext.DEPTH_TEST),r.enable(WebGL2RenderingContext.BLEND),r.blendFunc(WebGL2RenderingContext.SRC_ALPHA,WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA);const{scaleBars:w}=this,b=this.viewer.scaleBarOptions.value;w.draw(this.renderViewport,this.navigationState.displayDimensionRenderInfo.value,this.navigationState.relativeDisplayScales.value,this.navigationState.zoomFactor.value/this.renderViewport.logicalHeight,b),r.disable(WebGL2RenderingContext.BLEND)}return this.offscreenFramebuffer.unbind(),this.setGLClippedViewport(),this.offscreenCopyHelper.draw(this.offscreenFramebuffer.colorBuffers[0].texture),!0}drawSliceViews(e){const{sliceViewRenderHelper:t}=this,{lightDirection:n,ambientLighting:s,directionalLighting:r,projectionParameters:{viewProjectionMat:o}}=e,a=this.viewer.showSliceViews.value;for(const[l,c]of this.sliceViews){if(!c&&!a)continue;const{width:d,height:u,invViewMatrix:h,viewportNormalInCanonicalCoordinates:p}=l.projectionParameters.value;if(d===0||u===0||!l.valid)continue;const m=Math.abs(C.eR.dot(n,p)),g=s+m*r,v=PO;C.pB.identity(v),v[0]=d/2,v[5]=-u/2,C.pB.multiply(v,h,v),C.pB.multiply(v,o,v);const y=yb,S=this.viewer.crossSectionBackgroundColor.value;y[0]=S[0],y[1]=S[1],y[2]=S[2],y[3]=1,t.draw(l.offscreenFramebuffer.colorBuffers[0].texture,v,C.ln.fromValues(g,g,g,1),yb,0,0,1,1)}}drawAxisLines(){const{zoomFactor:{value:e}}=this.viewer.navigationState,t=this.projectionParameters.value,n=Math.min(t.logicalWidth,t.logicalHeight)/this.renderViewport.logicalHeight/4,s=e*n,{gl:r}=this;r.drawBuffers([r.COLOR_ATTACHMENT0]),this.axesLineHelper.draw(ob(t,s),!1)}zoomByMouse(e){this.navigationState.zoomBy(e)}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */var FO=(i=>(i[i.COLOR=0]="COLOR",i[i.PICK=1]="PICK",i[i.NUM_TEXTURES=2]="NUM_TEXTURES",i))(FO||{});function UO(i){i.addOutputBuffer("vec4","out_fragColor",0),i.addOutputBuffer("highp vec4","out_pickId",1),i.addFragmentCode(` +void emit(vec4 color, highp uint pickId) { + out_fragColor = color; + float pickIdFloat = float(pickId); + out_pickId = vec4(pickIdFloat, pickIdFloat, pickIdFloat, 1.0); +} +`)}function $O(i){i.addOutputBuffer("vec4","out_fragColor",null),i.addFragmentCode(` +void emit(vec4 color, highp uint pickId) { + out_fragColor = color; +} +`)}const os=C.eR.create(),GO=C.eR.create(),zO=C.ln.create();class Sl extends gb{constructor(e,t,n,s){super(e,t,s),this.sliceView=n,this.axesLineHelper=this.registerDisposer(vl.get(this.gl)),this.sliceViewRenderHelper=this.registerDisposer(ia.get(this.gl,$O)),this.colorFactor=C.ln.fromValues(1,1,1,1),this.pickIDs=new lb,this.offscreenFramebuffer=this.registerDisposer(new $n(this.gl,{colorBuffers:[new gn(this.gl,WebGL2RenderingContext.RGBA8,WebGL2RenderingContext.RGBA,WebGL2RenderingContext.UNSIGNED_BYTE),new gn(this.gl,WebGL2RenderingContext.R32F,WebGL2RenderingContext.RED,WebGL2RenderingContext.FLOAT)]})),this.offscreenCopyHelper=this.registerDisposer(Dn.get(this.gl)),this.scaleBars=this.registerDisposer(new mb(this.gl)),s.wireFrame.changed.add(()=>this.scheduleRedraw()),Z(t,"rotate-via-mouse-drag",r=>{const{mouseState:o}=this.viewer;if(o.updateUnconditionally()){const a=Float32Array.from(o.position);zt(r.detail,(l,c,d)=>{this.context.flagContinuousCameraMotion();const{pose:u}=this.navigationState,h=C.eR.transformQuat(os,C.T2[0],u.orientation.orientation),p=C.eR.transformQuat(GO,C.T2[1],u.orientation.orientation);this.viewer.navigationState.pose.rotateAbsolute(p,-c/4*Math.PI/180,a),this.viewer.navigationState.pose.rotateAbsolute(h,-d/4*Math.PI/180,a)})}}),Z(t,"rotate-in-plane-via-touchrotate",r=>{const{detail:o}=r,{mouseState:a}=this.viewer;this.handleMouseMove(o.centerX,o.centerY),a.updateUnconditionally()&&(this.context.flagContinuousCameraMotion(),this.navigationState.pose.rotateAbsolute(this.sliceView.projectionParameters.value.viewportNormalInCanonicalCoordinates,o.angle-o.prevAngle,a.position))}),this.registerDisposer(n),this.visibleLayerTracker=_g(this.viewer.layerManager,Fi,this.viewer.visibleLayerRoles,this),this.registerDisposer(s.crossSectionBackgroundColor.changed.add(()=>this.scheduleRedraw())),this.registerDisposer(n.visibility.add(this.visibility)),this.registerDisposer(n.viewChanged.add(()=>{this.visible&&e.scheduleRedraw()})),this.registerDisposer(s.showAxisLines.changed.add(()=>{this.visible&&this.scheduleRedraw()})),this.registerDisposer(s.showScaleBar.changed.add(()=>{this.visible&&this.context.scheduleRedraw()})),this.registerDisposer(s.scaleBarOptions.changed.add(()=>{this.visible&&this.context.scheduleRedraw()}))}flushBackendProjectionParameters(){this.sliceView.flushBackendProjectionParameters()}get displayDimensionRenderInfo(){return this.navigationState.displayDimensionRenderInfo}get rpc(){return this.sliceView.rpc}get rpcId(){return this.sliceView.rpcId}get navigationState(){return this.sliceView.navigationState}translateByViewportPixels(e,t){const{pose:n}=this.viewer.navigationState;n.updateDisplayPosition(s=>{C.eR.set(s,-e,-t,0),C.eR.transformMat4(s,s,this.sliceView.projectionParameters.value.invViewMatrix)})}translateDataPointByViewportPixels(e,t,n,s){const r=this.sliceView.projectionParameters.value;return C.eR.transformMat4(e,t,r.viewMatrix),C.eR.set(e,e[0]+n,e[1]+s,e[2]),C.eR.transformMat4(e,e,r.invViewMatrix),e}isReady(){if(!this.visible)return!1;const{sliceView:e}=this;if(this.ensureBoundsUpdated(),!e.isReady())return!1;const t={projectionParameters:e.projectionParameters.value,sliceView:e};for(const[n,s]of this.visibleLayerTracker.visibleLayers)if(!n.isReady(t,s))return!1;return!0}drawWithPicking(e){const{sliceView:t}=this;if(!t.valid)return!1;t.updateRendering();const n=t.projectionParameters.value,{width:s,height:r,invViewProjectionMat:o}=n;C.pB.copy(e.invTransform,o);const{gl:a}=this;this.offscreenFramebuffer.bind(s,r),a.disable(WebGL2RenderingContext.SCISSOR_TEST),this.gl.clearColor(0,0,0,0),a.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT);const l=zO,c=this.viewer.crossSectionBackgroundColor.value;l[0]=c[0],l[1]=c[1],l[2]=c[2],l[3]=1,this.offscreenFramebuffer.bindSingle(0),this.sliceViewRenderHelper.draw(t.offscreenFramebuffer.colorBuffers[0].texture,C.r3,this.colorFactor,l,0,0,1,1);const{visibleLayers:d}=this.visibleLayerTracker,{pickIDs:u}=this;u.clear();const h=()=>{a.disable(WebGL2RenderingContext.SCISSOR_TEST),a.enable(WebGL2RenderingContext.BLEND),a.blendFunc(WebGL2RenderingContext.SRC_ALPHA,WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA),this.offscreenFramebuffer.bind(s,r)};h();const p={wireFrame:this.viewer.wireFrame.value,projectionParameters:n,pickIDs:u,emitter:UO,emitColor:!0,emitPickID:!0,sliceView:t,bindFramebuffer:h,frameNumber:this.context.frameNumber};for(const[m,g]of d)m.draw(p,g);if(a.disable(WebGL2RenderingContext.BLEND),this.viewer.showAxisLines.value||this.viewer.showScaleBar.value){if(this.offscreenFramebuffer.bindSingle(0),this.viewer.showAxisLines.value){const m=Math.min(n.logicalWidth,n.logicalHeight)/4*1.5,{zoomFactor:{value:g}}=this.viewer.navigationState;this.axesLineHelper.draw((0,C.Qi)(ob(n,m*g)))}this.viewer.showScaleBar.value&&(a.enable(WebGL2RenderingContext.BLEND),a.blendFunc(WebGL2RenderingContext.SRC_ALPHA,WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA),this.scaleBars.draw(n,this.navigationState.displayDimensionRenderInfo.value,this.navigationState.relativeDisplayScales.value,this.navigationState.zoomFactor.value,this.viewer.scaleBarOptions.value),a.disable(WebGL2RenderingContext.BLEND))}return this.offscreenFramebuffer.unbind(),this.setGLClippedViewport(),this.offscreenCopyHelper.draw(this.offscreenFramebuffer.colorBuffers[0].texture),!0}ensureBoundsUpdated(){super.ensureBoundsUpdated(),this.sliceView.projectionParameters.setViewport(this.renderViewport)}issuePickRequest(e,t){const{offscreenFramebuffer:n}=this;n.readPixelFloat32IntoBuffer(1,e-Et,t-Et,0,je,je)}completePickRequest(e,t,n,s){const{mouseState:r}=this.viewer;r.pickedRenderLayer=null,fb(n,0,4,e,t,s.viewportWidth,s.viewportHeight);const{viewportWidth:o,viewportHeight:a}=s,l=yl.length,{value:c}=this.navigationState.position,d=c.length,u=this.navigationState.pose.displayDimensions.value,{displayRank:h,displayDimensionIndices:p}=u,m=(y,S,w)=>{const b=e+y,x=t+S;os[0]=2*b/o-1,os[1]=2*x/a-1,os[2]=0,C.eR.transformMat4(os,os,s.invTransform),w.set(c);for(let E=0;E{let{position:b}=r;b.length!==d&&(b=r.position=new Float32Array(d)),m(y-Et,S-Et,b),this.pickIDs.setMouseState(r,w),r.setActive(!0)};for(let y=0;y1024){const e=Math.log2(i)|0,t=i/2**e;return`${rm(t,1)}p${e}`}return i.toString()}const JO=[i=>i.name,i=>i.scaleFactor],jO=2e3;class YO extends T.O8{constructor(e,t,n,s="px"){super(),this.displayDimensionRenderInfo=e,this.zoom=t,this.depthRange=n,this.displayUnit=s,this.element=document.createElement("div"),this.dimensionGridContainer=document.createElement("div"),this.depthGridContainer=document.createElement("div"),this.defaultCheckbox=document.createElement("input"),this.dimensionElements=Array.from(Array(3),(g,v)=>{const y=document.createElement("div");y.classList.add("neuroglancer-display-dimensions-widget-dimension"),y.style.display="contents",Z(y,"adjust-via-wheel",D=>{const I=D.detail,{deltaY:L}=I;L!==0&&this.zoomDimension(v,Math.sign(L))});const S=document.createElement("input");S.classList.add("neuroglancer-display-dimensions-widget-name"),S.title="Change display dimensions",S.spellcheck=!1,S.autocomplete="off",S.style.color=WO[v],S.style.gridColumn="1",S.style.gridRow=`${v+1}`,S.addEventListener("focus",()=>{S.select()}),y.appendChild(S);const w=document.createElement("span");w.classList.add("neuroglancer-display-dimensions-widget-scale-factor");const b=document.createElement("input");b.spellcheck=!1,b.title="Change relative scale at which dimension is displayed",b.autocomplete="off",w.style.gridColumn="2",w.style.gridRow=`${v+1}`,b.addEventListener("focus",()=>{b.select()}),w.appendChild(b),y.appendChild(w);const x=document.createElement("span");x.classList.add("neuroglancer-display-dimensions-widget-scale"),x.style.gridColumn="3",x.style.gridRow=`${v+1}`,y.appendChild(x),this.dimensionGridContainer.appendChild(y);const E={name:S,container:y,scaleFactor:b,scale:x,scaleFactorModified:!1};S.addEventListener("input",()=>{$t(S),this.updateNameValidity()}),Z(S,"commit",()=>{this.updateNames()}),S.addEventListener("blur",D=>{const{relatedTarget:I}=D;this.dimensionElements.some(L=>L.name===I)||this.updateNames()||this.updateView()}),w.addEventListener("click",D=>{const{target:I}=D;I!==b&&(b.focus(),D.preventDefault())}),b.addEventListener("input",()=>{$t(b),E.scaleFactorModified=!0}),Z(b,"commit",()=>{this.updateScaleFactors()}),b.addEventListener("blur",()=>{this.updateScaleFactors()||this.updateView()});for(const D of JO)Z(D(E),"move-up",()=>{v!==0&&D(this.dimensionElements[v-1]).focus()}),Z(D(E),"move-down",()=>{v!==2&&D(this.dimensionElements[v+1]).focus()});return E}),this.scheduleUpdateView=(0,Qe.t)(()=>this.updateView());const{element:r,dimensionGridContainer:o,defaultCheckbox:a}=this,l=document.createElement("label"),c=this.registerCancellable((0,Fe.A)(()=>{r.dataset.active="false"},jO)),d=()=>{r.dataset.active="true",c()};this.registerDisposer(t.changed.add(d)),this.registerDisposer(e.relativeDisplayScales.changed.add(d)),this.registerDisposer(n.changed.add(d)),r.classList.add("neuroglancer-display-dimensions-widget"),r.appendChild(o),o.classList.add("neuroglancer-display-dimensions-widget-dimension-grid"),r.addEventListener("pointerleave",()=>{const g=document.activeElement;g instanceof HTMLElement&&r.contains(g)&&g.blur()}),a.type="checkbox",l.appendChild(a),l.appendChild(document.createTextNode("Default")),l.title="Display first 3 dimensions",l.classList.add("neuroglancer-display-dimensions-widget-default"),a.addEventListener("change",()=>{this.updateDefault()}),o.appendChild(l),this.registerDisposer(e),this.registerDisposer(n),this.registerDisposer(t.changed.add(this.scheduleUpdateView)),this.registerDisposer(e.changed.add(this.scheduleUpdateView));const u=this.registerDisposer(new yn(r,Sb));u.allShortcutsAreGlobal=!0,this.registerDisposer(new tn(r,Sb)),Z(o,"cancel",()=>{this.updateView();const g=document.activeElement;g instanceof HTMLElement&&r.contains(g)&&g.blur()});const{depthGridContainer:h}=this;h.classList.add("neuroglancer-depth-range-widget-grid"),r.appendChild(h);const p=document.createElement("label"),m=document.createElement("input");m.type="checkbox",p.classList.add("neuroglancer-depth-range-relative-checkbox-label"),m.classList.add("neuroglancer-depth-range-relative-checkbox"),p.appendChild(m),p.appendChild(document.createTextNode("Zoom-relative")),m.addEventListener("change",()=>{const g=m.checked;let v=this.depthRange.value;g!==v<0&&(g?v=-v/this.zoom.value:v=-v*this.zoom.value,this.depthRange.value=v)}),p.title="Depth range is multiplied by scale",r.appendChild(p),Z(h,"adjust-via-wheel",g=>{const v=g.detail,{deltaY:y}=v;if(y===0)return;const S=this.depthRange.value;this.depthRange.value=S*2**Math.sign(y)}),this.registerDisposer((0,_.no)((g,v,{factors:y})=>{Me(h);const{displayRank:S,globalDimensionNames:w,displayDimensionIndices:b,displayDimensionUnits:x,displayDimensionScales:E,canonicalVoxelFactors:D}=v,I=[],L=()=>{m.checked=this.depthRange.value<0;let O=this.depthRange.value;O<0&&(O*=-this.zoom.value);for(const V of I){const{input:z}=V;z.value=Ri(O*V.scale,V.unit,{precision:2,elide1:!1}),$t(z)}},N=O=>{const V=sr(O.input.value);if(V===void 0||V.unit!==O.unit)return!1;let z=V.scale/O.scale;return this.depthRange.value<0&&(z=-z/this.zoom.value),this.depthRange.value=z,!0};for(let O=0;Oce.unit===Y&&ce.factor===Q);if(X===void 0){const ce=document.createElement("div");ce.title="Visible depth range",ce.style.display="contents",h.appendChild(ce);const oe=document.createElement("span");oe.textContent="\xB1",ce.appendChild(oe);const Se=document.createElement("input");Se.spellcheck=!1,Se.autocomplete="off",Se.addEventListener("focus",()=>{Se.select()}),Z(Se,"commit",()=>{N(X)}),Se.addEventListener("change",()=>{N(X)||L()}),Se.addEventListener("input",()=>{$t(Se)}),ce.appendChild(Se);const Ke=document.createElement("span");Ke.classList.add("neuroglancer-depth-range-widget-dimension-names"),ce.appendChild(Ke),X={unit:Y,factor:Q,dimensionNames:[],input:Se,label:Ke,scale:E[O]/D[O]},I.push(X)}X.dimensionNames.push(z)}for(const O of I)O.dimensionNames.length!==S&&(O.label.textContent=O.dimensionNames.join(" "));g.registerDisposer(Z(h,"cancel",()=>{L();const O=document.activeElement;O instanceof HTMLElement&&h.contains(O)&&O.blur()}));const k=g.registerCancellable((0,Qe.t)(L));g.registerDisposer(this.depthRange.changed.add(k)),g.registerDisposer(this.zoom.changed.add(k)),L()},e,this.relativeDisplayScales)),this.updateView()}zoomDimension(e,t){this.updateScaleFactors();const{displayDimensions:n}=this,{relativeDisplayScales:s}=this,{displayDimensionIndices:r}=n.value,o=r[e];if(o===-1)return;const{factors:a}=s.value,l=new Float64Array(a);l[o]*=2**-t,s.setFactors(l)}updateNameValidity(){const{dimensionElements:e}=this,{displayDimensionIndices:t}=this.displayDimensions.value,n=e.map(l=>l.name.value),s=jl(n),r=this.displayDimensions.coordinateSpace.value,{names:o}=r,a=n.length;for(let l=0;la.name.value).filter(a=>a.length>0);if(!ho(e))return!1;const{displayDimensions:t}=this.displayDimensionRenderInfo;if(e.length===0)return t.reset(),!0;const n=new Int32Array(3);n.fill(-1);const s=t.coordinateSpace.value,{names:r}=s,o=e.length;for(let a=0;aat(n));for(let s=0;s<2;++s){const r=t[Math.min(t.length-1,s)];i.registerDisposer(Z(e.element,s===0?"toggle-layout":"toggle-layout-alternative",o=>{i.container.name=r,o.stopPropagation()}))}for(const s of t){const r=document.createElement("button"),o=document.createElement("div");r.appendChild(o),o.textContent=oh.get(s),r.title=`Switch to ${s} layout.`,r.addEventListener("click",()=>{i.container.name=s}),n.appendChild(r)}e.element.appendChild(n)}function XO(i,e){const t=new na(i.chunkManager,i.layerManager,e.navigationState.addRef(),i.wireFrame),n=()=>{const{width:{value:s},height:{value:r}}=e;t.projectionParameters.setViewport({width:s,height:r,logicalWidth:s,logicalHeight:r,visibleLeftFraction:0,visibleTopFraction:0,visibleWidthFraction:1,visibleHeightFraction:1})};return t.registerDisposer(e.width.changed.add(n)),t.registerDisposer(e.height.changed.add(n)),n(),t}function lh(i,e,t){const n=new Map;(()=>{const r=new Set;for(const o of t.values()){if(r.add(o),n.has(o))continue;const a=XO(i,o);e.sliceViews.set(a,!0),n.set(o,a)}for(const[o,a]of n)r.has(o)||e.sliceViews.delete(a)})()}class ZO extends T.O8{constructor(e,t,n,s){super(),this.container=e,this.rootElement=t,this.viewer=n;const r=qO(n),{display:o}=n,a={...ah(e),showSliceViews:n.showPerspectiveSliceViews,showSliceViewsCheckbox:!0},l={...bl(n),showScaleBar:n.showScaleBar},c={...bl(n),showScaleBar:new nt(!1,!1)},d=(h,p,m,g)=>{const v=this.registerDisposer(new Sl(o,p,r.get(h),m));return g&&Zs(this,v),er(this,v,[h,`${h}-3d`]),v},u=[dn(1,rs("column",[dn(1,rs("row",[dn(1,h=>{d("xy",h,l,!0)}),dn(1,h=>{d("xz",h,c,!1)})])),dn(1,rs("row",[dn(1,h=>{const p=this.registerDisposer(new rh(o,h,a));for(const m of r.values())p.sliceViews.set(m.addRef(),!1);Zs(this,p),lh(n,p,s),er(this,p,["3d"])}),dn(1,h=>{d("yz",h,c,!1)})]))]))];rs("row",u)(t)}disposed(){Me(this.rootElement),super.disposed()}}class e_ extends T.O8{constructor(e,t,n,s,r,o){super(),this.container=e,this.rootElement=t,this.viewer=n,this.direction=s;const a=so(n,r),{display:l}=n,c={...ah(e),showSliceViews:n.showPerspectiveSliceViews,showSliceViewsCheckbox:!0},d={...bl(n),showScaleBar:n.showScaleBar};dn(1,rs(s,[dn(1,u=>{const h=this.registerDisposer(new Sl(l,u,a,d));Zs(this,h),er(this,h,[r,"4panel"])}),dn(1,u=>{const h=this.registerDisposer(new rh(l,u,c));h.sliceViews.set(a.addRef(),!1),lh(n,h,o),Zs(this,h),er(this,h,["3d","4panel"])})]))(t)}disposed(){Me(this.rootElement),super.disposed()}}class t_ extends T.O8{constructor(e,t,n,s){super(),this.container=e,this.rootElement=t,this.viewer=n;const r=so(n,s),o={...bl(n),showScaleBar:n.showScaleBar};rs("row",[dn(1,a=>{const l=this.registerDisposer(new Sl(n.display,a,r,o));Zs(this,l),er(this,l,["4panel",`${s}-3d`])})])(t)}disposed(){Me(this.rootElement),super.disposed()}}class n_ extends T.O8{constructor(e,t,n,s){super(),this.container=e,this.rootElement=t,this.viewer=n;const r={...ah(e),showSliceViews:new nt(!1,!1)};rs("row",[dn(1,o=>{const a=this.registerDisposer(new rh(n.display,o,r));lh(n,a,s),Zs(this,a),er(this,a,["4panel"])})])(t)}disposed(){Me(this.rootElement),super.disposed()}}const ch=new Map([["4panel",{factory:(i,e,t,n)=>new ZO(i,e,t,n)}],["3d",{factory:(i,e,t,n)=>new n_(i,e,t,n)}]]);for(const i of bb.keys()){ch.set(i,{factory:(t,n,s)=>new t_(t,n,s,i)});const e=`${i}-3d`;oh.set(i,Cb),oh.set(e,"\u25EB"),ch.set(e,{factory:(t,n,s,r)=>new e_(t,n,s,"row",i,r)})}function xb(i){const e=ch.get(i);if(e===void 0)throw new Error(`Invalid layout name: ${JSON.stringify(i)}.`);return e}function i_(i){return xb(i),i}class s_ extends T.O8{constructor(e){super(),this.width=new _.DN(1e3,f.We),this.height=new _.DN(1e3,f.We),this.changed=new j.IY,this.position=new Yp(e.position.addRef()),this.position.changed.add(this.changed.dispatch),this.orientation=new vc(e.pose.orientation.addRef()),this.orientation.changed.add(this.changed.dispatch),this.width.changed.add(this.changed.dispatch),this.height.changed.add(this.changed.dispatch),this.scale=new yc(e.zoomFactor.addRef(),e.zoomFactor.displayDimensionRenderInfo.addRef()),this.scale.changed.add(this.changed.dispatch),this.navigationState=this.registerDisposer(new ws(new Cs(this.position.value,e.pose.displayDimensionRenderInfo.addRef(),this.orientation.value),this.scale.value,e.depthRange.addRef()))}restoreState(e){(0,f.Rf)(e),Mt(e,"width",this.width),Mt(e,"height",this.height),Mt(e,"position",vr(this.position)),Mt(e,"orientation",this.orientation),Mt(e,"scale",this.scale),Mt(e,"zoom",vr(this.scale))}reset(){this.width.reset(),this.height.reset(),this.position.reset(),this.orientation.reset(),this.scale.reset()}toJSON(){return{width:this.width.toJSON(),height:this.height.toJSON(),position:this.position.toJSON(),orientation:this.orientation.toJSON(),scale:this.scale.toJSON()}}}class r_ extends rc{constructor(e){super((t,n)=>t.registerDisposer(t.registerDisposer(n).changed.add(this.changed.dispatch))),this.parentNavigationState=e,this.registerDisposer(e)}restoreState(e){(0,f.Rf)(e);for(const t of Object.keys(e)){const n=new s_(this.parentNavigationState);try{this.set(t,n.addRef()),n.restoreState(e[t])}finally{n.dispose()}}}reset(){this.clear()}toJSON(){if(this.size===0)return;const e={};for(const[t,n]of this)e[t]=n.toJSON();return e}}class o_ extends T.O8{constructor(e,t){super(),this.changed=new j.IY,this.orthographicProjection=new nt(!1),this.type=new _.DN(t,i_),this.type.changed.add(this.changed.dispatch),this.crossSections=this.registerDisposer(new r_(e.addRef())),this.crossSections.changed.add(this.changed.dispatch),this.orthographicProjection.changed.add(this.changed.dispatch),this.registerDisposer(e)}reset(){this.crossSections.clear(),this.orthographicProjection.reset(),this.type.reset()}restoreState(e){this.crossSections.clear(),this.orthographicProjection.reset(),typeof e=="string"?this.type.restoreState(e):((0,f.Rf)(e),(0,f.cQ)(e,"type",t=>this.type.restoreState(t)),(0,f.cQ)(e,"orthographicProjection",t=>this.orthographicProjection.restoreState(t)),(0,f.cQ)(e,"crossSections",t=>t!==void 0&&this.crossSections.restoreState(t)))}toJSON(){const{type:e,crossSections:t,orthographicProjection:n}=this,s=n.toJSON();return t.size===0&&s===void 0?e.value:{type:e.value,crossSections:t.toJSON(),orthographicProjection:s}}}class a_ extends T.O8{constructor(e,t){super(),this.viewer=e,this.element=document.createElement("div"),this.specification=this.registerDisposer(new o_(this.viewer.navigationState.addRef(),t)),this.element.style.flex="1";const n=this.registerCancellable((0,Fe.A)(()=>this.updateLayout(),0));this.specification.type.changed.add(n),Z(this.element,"toggle-orthographic-projection",()=>this.specification.orthographicProjection.toggle()),this.registerDisposer(this.viewer.display.updateStarted.add(()=>n.flush())),n()}get name(){return this.specification.type.value}set name(e){this.specification.type.value=e}get changed(){return this.specification.changed}toJSON(){return this.specification.toJSON()}restoreState(e){this.specification.restoreState(e)}reset(){this.specification.reset()}disposeLayout(){const{layout:e}=this;e!==void 0&&(e.dispose(),this.layout=void 0)}updateLayout(){this.disposeLayout(),this.layout=xb(this.name).factory(this,this.element,this.viewer,this.specification.crossSections)}disposed(){this.disposeLayout(),super.disposed()}}const l_=typeof{cave:{url:"middleauth+https://global.daf-apis.com/nglstate/api/v1/post",default:!0}}<"u"&&Object.keys({cave:{url:"middleauth+https://global.daf-apis.com/nglstate/api/v1/post",default:!0}}).length>0;class c_ extends T.O8{constructor(e){if(super(),this.element=document.createElement("div"),this.button=Ne({text:"Share",title:"Share State"}),typeof{cave:{url:"middleauth+https://global.daf-apis.com/nglstate/api/v1/post",default:!0}}>"u")throw new Error("Cannot construct StateSare without defining STATE_SERVERS");if(Object.keys({cave:{url:"middleauth+https://global.daf-apis.com/nglstate/api/v1/post",default:!0}}).length>1){const t=document.createElement("select");t.style.marginRight="5px",this.registerDisposer(e.selectedStateServer.changed.add(()=>{const n=e.selectedStateServer.value;Object.values({cave:{url:"middleauth+https://global.daf-apis.com/nglstate/api/v1/post",default:!0}}).map(s=>s.url).includes(n)&&(t.value=n)})),this.registerEventListener(t,"change",()=>{e.selectedStateServer.value=t.value});for(const[n,s]of Object.entries({cave:{url:"middleauth+https://global.daf-apis.com/nglstate/api/v1/post",default:!0}})){const r=document.createElement("option");r.textContent=n,r.value=s.url,r.selected=!!s.default,t.appendChild(r)}this.element.appendChild(t),this.selectStateServerElement=t}this.element.appendChild(this.button),this.registerEventListener(this.button,"click",()=>{const t=this.selectStateServerElement?this.selectStateServerElement.value:Object.values({cave:{url:"middleauth+https://global.daf-apis.com/nglstate/api/v1/post",default:!0}})[0].url,n=new URL(t).protocol,{url:s,credentialsProvider:r}=wn(t,Zn);pe.forPromise(Nt(r,s,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e.state.toJSON())},ke.cj).then(o=>{const a=new URL(o).protocol,l=o.substring(a.length),c=`${window.location.origin}/#!${n}${l}`;navigator.clipboard.writeText(c).then(()=>{pe.showTemporaryMessage("Share link copied to clipboard")})}).catch(()=>{pe.showTemporaryMessage("Could not access state server.",4e3)}),{initialMessage:`Posting state to ${t}.`,delay:!0,errorPrefix:""})})}disposed(){this.element.remove(),super.disposed()}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function d_(i){return i.startsWith("key")?i.substring(3):i.startsWith("digit")||i.startsWith("arrow")?i.substring(5):i}function u_(i){return i.split("+").map(d_).join("+")}const h_={...Ui,side:"left",row:1};class p_{constructor(){this.location=new Si(h_)}get changed(){return this.location.changed}toJSON(){return(0,f.Zu)(this.location.toJSON())}reset(){this.location.reset()}restoreState(e){this.location.restoreState(e)}}class f_ extends ji{constructor(e,t,n,s,r){super(e,t.location),this.bindings=n,this.toolBinder=r,this.scroll=document.createElement("div"),this.addTitleBar({title:"Help"});const o=document.createElement("div");o.classList.add("neuroglancer-help-body");const{scroll:a}=this;a.classList.add("neuroglancer-help-scroll-container"),o.appendChild(a),this.addBody(o);const l=this.registerCancellable((0,Qe.t)(()=>this.updateView()));this.registerDisposer(r.changed.add(l)),this.registerDisposer(s.layersChanged.add(l)),this.updateView()}updateView(){const{scroll:e,bindings:t,toolBinder:n}=this;if(Me(e),typeof NEUROGLANCER_BUILD_INFO<"u"){const d=document.createElement("h2");d.textContent="Build info";const u=document.createElement("div");u.classList.add("neuroglancer-build-info");const h=document.createElement("a"),{tag:p,url:m,timestamp:g}=NEUROGLANCER_BUILD_INFO;if(h.textContent=p,h.target="_blank",m!==void 0&&(h.href=m),e.appendChild(d),u.appendChild(h),g!==void 0){const v=document.createElement("div");v.classList.add("neuroglancer-build-timestamp");const y=Intl.DateTimeFormat("en",{hour12:!1,dateStyle:"medium",timeStyle:"long"}).format(new Date(g));v.textContent=`Built at ${y}`,u.append(v)}e.appendChild(u)}const s=new Map;function r(d,u){for(const h of d.parents)h.label!==void 0?o(h.label,h):r(h,u);for(const[h,p]of d.bindings.entries()){const m=h.indexOf(":"),g=h.substring(m+1);u.set(g,p.action)}}function o(d,u){if(s.has(u))return;const h={label:d,entries:new Map};r(u,h.entries),s.set(u,h)}for(const[d,u]of t)o(d,u);const a=(d,u)=>{const h=document.createElement("h2");h.textContent=d,e.appendChild(h);for(const[p,m]of u){const g=document.createElement("div");g.className="dt",g.textContent=u_(p);const v=document.createElement("div");v.className="dd",v.textContent=m,e.appendChild(g),e.appendChild(v)}},l=new Map;for(const[d,u]of n.bindings)if(u.context instanceof Rn){let h=l.get(u.context);h===void 0&&(h=[],l.set(u.context,h)),h.push([`shift+key${d.toLowerCase()}`,u.description])}const c=Array.from(l.entries());c.length>0&&(c[0][0].manager.root.layerManager.updateNonArchivedLayerIndices(),c.sort((d,u)=>d[0].managedLayer.nonArchivedLayerIndex-u[0].managedLayer.nonArchivedLayerIndex));for(const[d,u]of c)u.sort(),a(`Tool bindings for layer ${d.managedLayer.nonArchivedLayerIndex+1}: ${d.managedLayer.name}`,u);for(const d of s.values())a(d.label,d.entries)}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function g_(i,e){i.style.display="block";const{offsetWidth:t,offsetHeight:n}=i,s=document.documentElement.clientWidth,r=document.documentElement.clientHeight,o=document.documentElement.scrollLeft+Math.min(s-t,e.clientX),a=document.documentElement.scrollTop+Math.min(r-n,e.clientY);i.style.left=o+"px",i.style.top=a+"px"}class m_ extends T.O8{constructor(e){super(),this.element=document.createElement("div"),this.parentDisposers=new Map,this.disabledValue=!1,this.opened=new j.IY,this.closed=new j.IY;const{element:t}=this;t.className="neuroglancer-context-menu",t.style.display="none",t.tabIndex=-1,document.body.appendChild(t),e!==void 0&&this.registerParent(e)}get disabled(){return this.disabledValue}set disabled(e){this.disabledValue!==e&&(this.disabledValue=e,e&&this.hide())}get open(){return this.menuDisposer!==void 0}registerParent(e){const{parentDisposers:t}=this;t.has(e)||t.set(e,(0,T.K6)(e,"contextmenu",n=>{this.show(n),n.stopPropagation(),n.preventDefault()}))}show(e){if(this.disabledValue)return;this.hide();const{element:t}=this,n=(0,T.K6)(document,"mousedown",o=>{o.target instanceof Node&&!t.contains(o.target)&&this.hide()},!0),s=(0,T.K6)(document,"keydown",o=>{o.code==="Escape"&&this.hide()},!0),r=()=>{s(),n(),t.style.display="none"};this.opened.dispatch(),g_(t,e),this.menuDisposer=r}unregisterParent(e){const{parentDisposers:t}=this,n=t.get(e);n!==void 0&&(n(),t.delete(e))}disposed(){const{parentDisposers:e}=this;for(const t of e.values())t();e.clear(),at(this.element)}hide(){this.menuDisposer!==void 0&&(this.menuDisposer(),this.menuDisposer=void 0,this.closed.dispatch())}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Eb(i){return Le(new TextEncoder().encode(i))}function v_(i){return new TextDecoder().decode(We(i))}function T2(i,e){return i+Eb(JSON.stringify(e))}function y_(i,e){if(i.startsWith(e))try{const t=v_(i.substring(e.length));return JSON.parse(t)}catch{return}}function S_(i,e){return i+Eb(JSON.stringify(e))}function b_(i,e){for(const t of i){const n=y_(t,e);if(n!==void 0)return{parameters:n,dragType:t}}}let Tb;function dh(i,e){return i.dataTransfer.dropEffect=e,Tb=e,e}function uh(){return Tb}function C_(i){return i.draggable=!0,(0,T.K6)(i,"dragstart",e=>{e.stopPropagation(),e.preventDefault()})}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const Db="neuroglancer-layer\0";let un;function Ib(i,e){i.dataTransfer.setData(S_(Db,e.layers.map(s=>({name:s.name,visible:s.visible}))),JSON.stringify({layers:e.layers.map(s=>s.toJSON()),layout:e.layoutSpec})),un!==void 0&&un.disposer();let t;const n=()=>{e.manager.unregisterDisposer(n);for(const s of e.layers)s.dispose();e.manager.dispose(),un===t&&(un=void 0)};un=t={manager:e.manager.addRef(),layers:e.layers.map(s=>s.addRef()),layoutSpec:e.layoutSpec,isLayerListPanel:e.isLayerListPanel??!1,disposer:n}}function Cl(i="none"){if(un!==void 0){if(i==="move"){const e=new Set(un.layers);un.manager.layerManager.filter(t=>!e.has(t))}un.disposer()}}function wl(i){return b_(i.dataTransfer.types,Db)}function Lb(i){if(un!==void 0&&un.manager.rootLayers===i.rootLayers)return un}class Rb{initializeExternalLayers(e){const{dragType:t}=this;if(t!==void 0)try{const{layers:n,layout:s}=JSON.parse(e.dataTransfer.getData(t));if(!Array.isArray(n)||this.numSourceLayers!==n.length)throw new Error("Invalid layer drop data");this.layoutSpec=s;for(const[r,o]of this.layers)WT(r,n[o])}catch{return!1}return!0}updateArchiveStates(e){const{targetIsLayerListPanel:t}=this,n=e.dataTransfer.dropEffect;for(const s of this.layers.keys()){let r=t;t&&!s.archived&&n!=="copy"&&this.sourceIsLayerListPanel&&(r=!1),(s.archived!==r||r&&s.visible)&&(s.archived=r,r&&(s.visible=!1),s.layerChanged.dispatch())}}get method(){return this.sourceManager!==void 0?this.manager===this.sourceManager&&this.sourceIsLayerListPanel===this.targetIsLayerListPanel?"move":"link":"copy"}compatibleWithMethod(e){return this.method===e?!0:this.forceCopy&&e!=="copy"?!1:!this.moveSupported&&e==="move"}}function kb(i,e,t){let n;i.shiftKey?n="copy":i.ctrlKey&&t?n="move":n=e;let s="";const r=o=>{s!==""&&(s+=", "),s+=o};return e!=="none"&&n!==e&&(i.shiftKey?r(`release SHIFT to ${e}`):r(`release CONTROL to ${e}`)),n!=="copy"&&r("hold SHIFT to copy"),n!=="move"&&t&&e!=="move"&&r("hold CONTROL to move"),{dropEffect:n,dropEffectMessage:s}}function Pb(i,e,t,n){const s=Lb(e);let r=!1,o;return s===void 0?o="copy":n?(s.isLayerListPanel||(r=!0),o="link"):s.manager===e&&s.isLayerListPanel===t?(o="move",r=!0):t?o="none":(s.isLayerListPanel||(r=!0),o="link"),kb(i,o,r)}function w_(i,e,t,n){const s=Pb(i,e,t,n);return dh(i,s.dropEffect),s}function hh(i,e,t){const{forceCopy:n,newTarget:s,isLayerListPanel:r=!1}=t,o=Lb(e);if(!n&&o!==void 0){const l=!s&&o.manager===e&&(o.isLayerListPanel===r||o.isLayerListPanel),c=new Rb;return c.manager=e,c.numSourceLayers=o.layers.length,c.sourceManager=o.manager,c.targetIsLayerListPanel=r,c.sourceIsLayerListPanel=o.isLayerListPanel,c.moveSupported=l,c.layers=new Map,c.forceCopy=!1,c.layoutSpec=o.layoutSpec,l?o.layers.forEach((d,u)=>{c.layers.set(d,u)}):o.layers.forEach((d,u)=>{(s||!e.layerManager.has(d))&&c.layers.set(d.addRef(),u)}),c}const a=wl(i);if(a!==void 0)try{const l=(0,f.$v)(a.parameters,(d,u)=>{const h=(0,f.cQ)(d,"name",f.zr);let p=(0,f.cQ)(d,"visible",f.aO);const m=new Kc(h,e);return r&&(p=!1),m.visible=p,m.archived=r,[m,u]}),c=new Rb;return c.numSourceLayers=l.length,c.targetIsLayerListPanel=r,c.sourceIsLayerListPanel=!1,c.sourceManager=void 0,c.moveSupported=!1,c.forceCopy=o!==void 0,c.manager=e,c.dragType=a.dragType,c.layers=new Map(l),c}catch{}}function ph(i,e){return i.moveSupported?!1:(i.manager.layerManager.filter(t=>!i.layers.has(t)),e!==void 0&&i.layers.has(e))}function xl(i,e,t,n=!1){function s(r,o){let a=i.dropLayers;const{dropEffect:l,dropEffectMessage:c}=o?Pb(r,i.manager,n,!1):{dropEffect:uh(),dropEffectMessage:""};if(l===void 0)return;dh(r,l);let d=!0;if(!(a!==void 0&&!a.compatibleWithMethod(l)&&(i.dropLayers=void 0,ph(a,t)))){if(a===void 0){if(a=i.dropLayers=hh(r,i.manager,{forceCopy:l==="copy",newTarget:!1,isLayerListPanel:n}),a===void 0)return;d=a.method==="move"}if(t!==void 0&&a.layers.has(t))return{dropLayers:a,dropEffect:l,dropEffectMessage:c};if(d){const{layerManager:u}=i.manager,h=new Set;let p=Number.POSITIVE_INFINITY;const m=u.managedLayers=u.managedLayers.filter((v,y)=>a.layers.has(v)?(p===Number.POSITIVE_INFINITY&&(p=y),h.add(v),!1):!0);let g;t!==void 0?(g=m.indexOf(t),p<=g&&++g):g=m.length;for(const v of a.layers.keys())h.has(v)||a.layers.delete(v);m.splice(g,0,...a.layers.keys()),u.layersChanged.dispatch()}else{let u;t!==void 0&&(u=i.manager.layerManager.managedLayers.indexOf(t));for(const h of a.layers.keys())i.manager.add(h,u)}return{dropLayers:a,dropEffect:l,dropEffectMessage:c}}}e.addEventListener("dragenter",r=>{s(r,!0)!==void 0?r.preventDefault():kt(i.element,"drop")}),e.addEventListener("drop",r=>{r.preventDefault(),i.dragEnterCount=0,kt(i.element,"drop");const o=s(r,!1)?.dropLayers;if(i.dropLayers=void 0,o!==void 0){if(!o.initializeExternalLayers(r)){ph(o);return}o.updateArchiveStates(r),Cl(o.method==="move"?void 0:r.dataTransfer.dropEffect)}}),e.addEventListener("dragover",r=>{const o=s(r,!0);if(o===void 0){kt(i.element,"drop");return}const{dropLayers:a,dropEffect:l,dropEffectMessage:c}=o,d=a.layers.size;let u="";const h=a.numSourceLayers===1?"":"s",p=a.numSourceLayers;if(l==="none")u=`Cannot link dragged layer${h} here`;else{const m=p===d?`${p}`:`${d}/${p}`;u=`Drop to ${l} ${m} layer${h}`}c&&(u+=` (${c})`),Cn(i.element,"drop",u),r.preventDefault(),r.stopPropagation()})}function Ab(i,e,t,n){e.draggable=!0,e.addEventListener("dragstart",s=>{Cn(e,"drag","Drag layer to another layer bar/panel (including in another Neuroglancer window), or to the left/top/right/bottom edge of a layer group"),Ib(s,{manager:i.manager,layers:[t],layoutSpec:n.getLayoutSpec(),isLayerListPanel:n.isLayerListPanel}),s.stopPropagation()}),e.addEventListener("dragend",()=>{kt(e,"drag"),Cl()})}function Mb(i){i.element.addEventListener("dragenter",()=>{++i.dragEnterCount}),i.element.addEventListener("dragleave",()=>{if(--i.dragEnterCount!==0)return;kt(i.element,"drop");const{dropLayers:e}=i;e!==void 0&&(ph(e),i.manager.layerManager.layersChanged.dispatch(),i.dropLayers=void 0)})}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class x_ extends T.O8{constructor(e,t){super(),this.layer=e,this.panel=t,this.element=document.createElement("div"),this.layerNumberElement=document.createElement("div"),this.labelElement=document.createElement("div"),this.visibleProgress=document.createElement("div"),this.prefetchProgress=document.createElement("div"),this.labelElementText=document.createTextNode(""),this.valueElement=document.createElement("div"),this.maxLength=0,this.prevValueText="";const{element:n,labelElement:s,layerNumberElement:r,valueElement:o,visibleProgress:a,prefetchProgress:l,labelElementText:c}=this;n.className="neuroglancer-layer-item neuroglancer-noselect",n.appendChild(a),n.appendChild(l),s.className="neuroglancer-layer-item-label",s.appendChild(c),this.registerDisposer(e.readyStateChanged.add(()=>{if(console.log("layer is ready",e.isReady()),e.isReady()&&e.layer instanceof Ct){const g=e.layer.graphConnection,v=Ne({text:"\u{1F558}",title:"Share State"});v.addEventListener("click",w=>{if(w.stopPropagation(),g.value instanceof is){const{timestamp:b}=g.value.state;b.reset()}});let y;const S=()=>{if(y&&y(),g.value instanceof is){n.appendChild(v);const{timestamp:w}=g.value.state,b=()=>{v.style.display=w.value>0?"inherit":"none"};y=this.registerDisposer(w.changed.add(b)),b()}else n.contains(v)&&n.removeChild(v)};S(),this.registerDisposer(g.changed.add(S))}})),a.className="neuroglancer-layer-item-visible-progress",l.className="neuroglancer-layer-item-prefetch-progress",r.className="neuroglancer-layer-item-number",o.className="neuroglancer-layer-item-value";const d=document.createElement("div");d.className="neuroglancer-layer-item-value-container";const u=document.createElement("div");u.className="neuroglancer-layer-item-button-container";const h=No();h.title="Remove layer from this layer group",h.addEventListener("click",g=>{this.panel.layerManager===this.panel.manager.rootLayers?this.layer.setArchived(!0):this.layer.containers.size>2?this.panel.layerManager.removeManagedLayer(this.layer):this.layer.setArchived(!0),g.stopPropagation()});const p=Mn();p.title="Delete this layer",p.addEventListener("click",g=>{Ms(this.layer),g.stopPropagation()}),n.appendChild(r),d.appendChild(o),d.appendChild(u),u.appendChild(h),u.appendChild(p),n.appendChild(s),n.appendChild(d);const m=this.registerDisposer(new xs(e.localPosition,e.localCoordinateSpaceCombiner,{copyButton:!1,velocity:e.localVelocity,getToolBinder:()=>e.layer?.toolBinder}));n.appendChild(m.element),m.element.addEventListener("click",g=>{g.stopPropagation()}),m.element.addEventListener("dblclick",g=>{g.stopPropagation()}),n.addEventListener("click",g=>{g.ctrlKey?t.selectedLayer.toggle(e):g.altKey?e.pickEnabled=!e.pickEnabled:e.setVisible(!e.visible)}),n.addEventListener("contextmenu",g=>{t.selectedLayer.layer=e,t.selectedLayer.visible=!0,g.stopPropagation(),g.preventDefault()}),Ab(t,n,e,{getLayoutSpec:()=>t.getLayoutSpecForDrag()}),xl(this.panel,n,this.layer)}update(){const{layer:e,element:t}=this;this.labelElementText.textContent=e.name,t.dataset.visible=e.visible.toString(),t.dataset.selected=(e===this.panel.selectedLayer.layer).toString(),t.dataset.pick=e.pickEnabled.toString();let n=`Click to ${e.visible?"hide":"show"}, control+click to show side panel`;e.supportsPickOption&&(n+=`, alt+click to ${e.pickEnabled?"disable":"enable"} spatial object selection`),n+=", drag to move, shift+drag to copy",t.title=n}disposed(){this.element.remove(),super.disposed()}}class E_ extends T.O8{constructor(e,t,n){super(),this.layerGroupViewer=e,this.getLayoutSpecForDrag=t,this.showLayerHoverValues=n,this.layerWidgets=new Map,this.element=document.createElement("div"),this.layerUpdateNeeded=!0,this.valueUpdateNeeded=!1,this.layerWidgetInsertionPoint=document.createElement("div"),this.positionWidget=this.registerDisposer(new xs(this.viewerNavigationState.position.value,this.manager.root.coordinateSpaceCombiner,{velocity:this.viewerNavigationState.velocity.velocity,getToolBinder:()=>this.layerGroupViewer.toolBinder})),this.dragEnterCount=0,this.scheduleUpdate=this.registerCancellable((0,Qe.t)(()=>this.update()));const{element:s,manager:r,selectedLayer:o}=this;s.className="neuroglancer-layer-panel",this.registerDisposer(r.layerSelectedValues.changed.add(()=>{this.handleLayerValuesChanged()})),this.registerDisposer(r.layerManager.layersChanged.add(()=>{this.handleLayersChanged()})),this.registerDisposer(o.changed.add(()=>{this.handleLayersChanged()})),this.registerDisposer(n.changed.add(()=>{this.handleLayerItemValueChanged()})),this.element.dataset.showHoverValues=this.showLayerHoverValues.value.toString(),this.layerWidgetInsertionPoint.style.display="none",this.element.appendChild(this.layerWidgetInsertionPoint);const a=Ne({svg:Fa,title:"Click to add layer, control+click/right click/\u2318+click to add local annotation layer."});a.classList.add("neuroglancer-layer-add-button");const l=this.dropZone=document.createElement("div");l.className="neuroglancer-layer-panel-drop-zone";const c=u=>{if(u.ctrlKey||u.metaKey||u.type==="contextmenu"){const h=$g(this.manager,"annotation",{type:"annotation",source:"local://annotations"});this.manager.add(h),this.selectedLayer.layer=h,this.selectedLayer.visible=!0}else this.addLayerMenu()};this.registerEventListener(a,"click",c),this.registerEventListener(a,"contextmenu",c),s.appendChild(a),s.appendChild(l),this.registerDisposer(C_(a)),s.appendChild(this.positionWidget.element);const d=()=>{const u=this.viewerNavigationState.position.link.value;this.positionWidget.element.style.display=u===Ro.LINKED?"none":""};this.registerDisposer(this.viewerNavigationState.position.link.changed.add(d)),d(),this.update(),this.updateChunkStatistics(),Mb(this),xl(this,l,void 0),this.registerDisposer(this.display.updateStarted.add(()=>this.updateLayers())),this.registerDisposer(r.chunkManager.layerChunkStatisticsUpdated.add(this.registerCancellable((0,Qe.t)(()=>this.updateChunkStatistics()))))}get layerManager(){return this.manager.layerManager}get manager(){return this.layerGroupViewer.layerSpecification}get display(){return this.layerGroupViewer.display}get selectedLayer(){return this.layerGroupViewer.selectedLayer}get viewerNavigationState(){return this.layerGroupViewer.viewerNavigationState}disposed(){this.layerWidgets.forEach(e=>e.dispose()),this.layerWidgets=void 0,at(this.element),super.disposed()}handleLayersChanged(){this.layerUpdateNeeded=!0,this.handleLayerValuesChanged()}handleLayerValuesChanged(){this.valueUpdateNeeded||(this.valueUpdateNeeded=!0,this.scheduleUpdate())}handleLayerItemValueChanged(){this.element.dataset.showHoverValues=this.showLayerHoverValues.value.toString()}update(){if(this.valueUpdateNeeded=!1,this.updateLayers(),this.showLayerHoverValues.value===!1)return;const e=this.manager.layerSelectedValues;for(const[t,n]of this.layerWidgets){const s=t.layer;let r="";if(s!==null){const o=e.get(s);if(o!==void 0){const{value:a}=o;a!==void 0&&(r=""+a)}}if(r!==n.prevValueText){if(n.prevValueText=r,r.length>n.maxLength){const o=n.maxLength=r.length;n.valueElement.style.width=`${o}ch`}n.valueElement.textContent=r}}}updateChunkStatistics(){for(const[e,t]of this.layerWidgets){let n=0,s=0,r=0,o=0;const a=e.layer;if(a!==null)for(const{layerChunkProgressInfo:l}of a.renderLayers)n+=l.numVisibleChunksNeeded,s+=l.numVisibleChunksAvailable,r+=l.numPrefetchChunksNeeded,o+=l.numPrefetchChunksAvailable;t.visibleProgress.style.width=`${s/Math.max(1,n)*100}%`,t.prefetchProgress.style.width=`${o/Math.max(1,r)*100}%`}}updateLayers(){if(!this.layerUpdateNeeded)return;this.layerUpdateNeeded=!1;const e=this.element,t=new Set;let n=this.layerWidgetInsertionPoint.nextElementSibling;this.manager.rootLayers.updateNonArchivedLayerIndices();for(const s of this.manager.layerManager.managedLayers){if(s.archived&&!this.dropLayers?.layers.has(s))continue;t.add(s);let r=this.layerWidgets.get(s);const o=s.nonArchivedLayerIndex;r===void 0&&(r=new x_(s,this),this.layerWidgets.set(s,r)),r.layerNumberElement.textContent=""+(1+o),r.update();const{element:a}=r;a!==n&&e.insertBefore(r.element,n),n=a.nextElementSibling}for(const[s,r]of this.layerWidgets)t.has(s)||(this.layerWidgets.delete(s),r.dispose())}addLayerMenu(){Qg(this.manager,this.selectedLayer)}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function Nb(i,e){const t=(0,T.K6)(i,"drop",o=>{if(o.preventDefault(),o.dataTransfer.types.indexOf(Fo)!==-1){o.stopPropagation();const a=(0,f.Rf)(JSON.parse(o.dataTransfer.getData(Fo))),l=(0,f.cQ)(a,"dimensions",Yl),c=(0,f.cQ)(a,"position",p=>(0,f.$v)(p,f.zo));if(c.length!==l.length)throw new Error("length mismatch between position and dimensions");const d=c.length,{coordinateSpace:{value:{names:u}},value:h}=e;for(let p=0;p{o.dataTransfer.types.indexOf(Fo)!==-1&&(o.dataTransfer.dropEffect="link",o.preventDefault(),o.stopPropagation())},s=(0,T.K6)(i,"dragenter",n),r=(0,T.K6)(i,"dragover",n);return()=>{s(),r(),t()}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const fh="neuroglancer-layer-group-viewer";function Ob(i){return i.dataTransfer.types.indexOf(fh)!==-1}let _n;function T_(i){if(_n&&_n.viewer.layerSpecification.rootLayers===i.rootLayers)return _n.viewer}function D_(i,e){const t=T_(e);let n,s=!1;return t===void 0||t.layerSpecification===t.layerSpecification.root?n="copy":(s=!0,n="move"),kb(i,n,s)}class I_ extends T.O8{constructor(e){super(),this.relativeDisplayScales=new Kw(e.navigationState.pose.relativeDisplayScales.addRef()),this.displayDimensions=new Xw(e.navigationState.pose.displayDimensions.addRef()),this.position=new Yp(e.navigationState.position.addRef()),this.velocity=this.registerDisposer(new Yw(e.velocity,this.position.link)),this.crossSectionOrientation=new vc(e.navigationState.pose.orientation.addRef()),this.displayDimensionRenderInfo=this.registerDisposer(new Zp(this.relativeDisplayScales.value,this.displayDimensions.value)),this.crossSectionScale=new yc(e.navigationState.zoomFactor.addRef(),this.displayDimensionRenderInfo.addRef()),this.crossSectionDepthRange=new nf(e.navigationState.depthRange.addRef(),this.displayDimensionRenderInfo),this.projectionDepthRange=new nf(e.perspectiveNavigationState.depthRange.addRef(),this.displayDimensionRenderInfo),this.navigationState=this.registerDisposer(new ws(new Cs(this.position.value,this.displayDimensionRenderInfo.addRef(),this.crossSectionOrientation.value),this.crossSectionScale.value,this.crossSectionDepthRange.value)),this.projectionOrientation=new vc(e.perspectiveNavigationState.pose.orientation.addRef()),this.projectionScale=new yc(e.perspectiveNavigationState.zoomFactor.addRef(),this.displayDimensionRenderInfo.addRef()),this.projectionNavigationState=this.registerDisposer(new ws(new Cs(this.position.value.addRef(),this.displayDimensionRenderInfo.addRef(),this.projectionOrientation.value),this.projectionScale.value,this.projectionDepthRange.value))}copyToParent(){for(const e of[this.relativeDisplayScales,this.displayDimensions,this.position,this.velocity,this.crossSectionOrientation,this.crossSectionScale,this.projectionOrientation,this.projectionScale])e.copyToPeer()}register(e){e.add("dimensionRenderScales",this.relativeDisplayScales),e.add("displayDimensions",this.displayDimensions),e.add("position",vr(this.position)),e.add("velocity",this.velocity),e.add("crossSectionOrientation",this.crossSectionOrientation),e.add("crossSectionScale",this.crossSectionScale),e.add("crossSectionDepth",this.crossSectionDepthRange),e.add("projectionOrientation",this.projectionOrientation),e.add("projectionScale",this.projectionScale),e.add("projectionDepth",this.projectionDepthRange)}}function L_(i,e){const t=new m_(i),n=t.element;n.classList.add("neuroglancer-layer-group-viewer-context-menu");const s=document.createElement("button");s.textContent="Remove layer group",n.appendChild(s),t.registerEventListener(s,"click",()=>{e.layerSpecification.layerManager.clear()});const{viewerNavigationState:r}=e;for(const[o,a]of[["Render scale factors",r.relativeDisplayScales.link],["Render dimensions",r.displayDimensions.link],["Position",r.position.link],["Cross-section orientation",r.crossSectionOrientation.link],["Cross-section zoom",r.crossSectionScale.link],["Cross-section depth range",r.crossSectionDepthRange.link],["3-D projection orientation",r.projectionOrientation.link],["3-D projection zoom",r.projectionScale.link],["3-D projection depth range",r.projectionDepthRange.link]]){const l=t.registerDisposer(new Bo(a)),c=document.createElement("label");c.style.display="flex",c.style.flexDirection="row",c.style.whiteSpace="nowrap",c.textContent=o,c.appendChild(l.element),n.appendChild(c)}return t}class ro extends T.O8{constructor(e,t,n={}){super(),this.element=e,this.viewerState=t,this.state=new fr,this.options={showLayerPanel:new nt(!0),showViewerMenu:!1,showLayerHoverValues:new nt(!0),...n},this.layerSpecification=this.registerDisposer(t.layerSpecification),this.toolBinder=this.registerDisposer(new Dc(this,this.layerSpecification.root.toolBinder)),this.viewerNavigationState=this.registerDisposer(new I_(t)),this.viewerNavigationState.register(this.state),this.registerDisposer((0,_.no)((s,r)=>{r===Ro.UNLINKED&&s.registerDisposer(new mc(this.layerSpecification.root.display,this.viewerNavigationState.position.value,this.viewerNavigationState.velocity.velocity))},this.viewerNavigationState.position.link)),this.layerSpecification instanceof zg?this.state.add("layers",this.layerSpecification):this.state.add("layers",{changed:this.layerSpecification.changed,toJSON:()=>this.layerSpecification.layerManager.managedLayers.map(s=>s.name),reset:()=>{throw new Error("not implemented")},restoreState:()=>{throw new Error("not implemented")}}),e.classList.add("neuroglancer-layer-group-viewer"),this.registerDisposer(new za(e)),this.layout=this.registerDisposer(new a_(this,"xy")),this.state.add("layout",this.layout),this.state.add("toolBindings",this.toolBinder),this.registerActionBindings(),this.registerDisposer(this.layerManager.useDirectly()),this.registerDisposer(Nb(e,this.navigationState.position)),this.registerDisposer(this.options.showLayerPanel.changed.add(this.registerCancellable((0,Fe.A)(()=>this.updateUI(),0)))),this.makeUI()}get perspectiveNavigationState(){return this.viewerNavigationState.projectionNavigationState}get navigationState(){return this.viewerNavigationState.navigationState}get selectionDetailsState(){return this.layerSpecification.root.selectionState}get display(){return this.viewerState.display}get selectedLayer(){return this.viewerState.selectedLayer}get layerManager(){return this.layerSpecification.layerManager}get chunkManager(){return this.layerSpecification.chunkManager}get mouseState(){return this.viewerState.mouseState}get showAxisLines(){return this.viewerState.showAxisLines}get wireFrame(){return this.viewerState.wireFrame}get enableAdaptiveDownsampling(){return this.viewerState.enableAdaptiveDownsampling}get showScaleBar(){return this.viewerState.showScaleBar}get showPerspectiveSliceViews(){return this.viewerState.showPerspectiveSliceViews}get inputEventBindings(){return this.viewerState.inputEventBindings}get visibility(){return this.viewerState.visibility}get visibleLayerRoles(){return this.viewerState.visibleLayerRoles}get crossSectionBackgroundColor(){return this.viewerState.crossSectionBackgroundColor}get perspectiveViewBackgroundColor(){return this.viewerState.perspectiveViewBackgroundColor}get scaleBarOptions(){return this.viewerState.scaleBarOptions}get changed(){return this.state.changed}bindAction(e,t){this.registerDisposer(Z(this.element,e,t))}registerActionBindings(){this.bindAction("add-layer",()=>{this.layerPanel&&this.layerPanel.addLayerMenu()}),this.bindAction("t-",()=>{this.navigationState.pose.translateNonDisplayDimension(0,-1)}),this.bindAction("t+",()=>{this.navigationState.pose.translateNonDisplayDimension(0,1)})}toJSON(){return{type:"viewer",...this.state.toJSON()}}reset(){this.state.reset()}restoreState(e){this.state.restoreState(e),Mt(e,"crossSectionZoom",vr(this.viewerNavigationState.crossSectionScale)),Mt(e,"perspectiveZoom",vr(this.viewerNavigationState.projectionScale)),Mt(e,"perspectiveOrientation",this.viewerNavigationState.projectionOrientation)}makeUI(){this.element.style.flex="1",this.element.style.display="flex",this.element.style.flexDirection="column",this.element.appendChild(this.layout.element),this.updateUI()}updateUI(){const{options:e}=this,t=e.showLayerPanel.value;if(this.layerPanel!==void 0&&!t){this.layerPanel.dispose(),this.layerPanel=void 0;return}if(t&&this.layerPanel===void 0){const n=this.layerPanel=new E_(this,()=>this.layout.toJSON(),this.options.showLayerHoverValues);if(e.showViewerMenu?(n.registerDisposer(L_(n.element,this)),n.element.title="Right click for options, drag to move/copy layer group."):n.element.title="Drag to move/copy layer group.",typeof NEUROGLANCER_SHOW_LAYER_BAR_EXTRA_BUTTONS<"u"&&NEUROGLANCER_SHOW_LAYER_BAR_EXTRA_BUTTONS===!0){{const r=document.createElement("button");r.textContent="Clear segments",r.title='De-select all objects ("x")',r.addEventListener("click",o=>{af(o,o,{action:"clear-segments"})}),n.element.appendChild(r)}for(const r of["3d","xy","xz","yz"]){const o=document.createElement("button");o.textContent=r,o.title=`Switch to ${r} layout`,o.addEventListener("click",()=>{let a;this.layout.name===r?r!=="3d"?a=`${r}-3d`:a="4panel":a=r,this.layout.name=a}),n.element.appendChild(o)}}n.element.draggable=!0;const s=n.element;s.addEventListener("dragstart",r=>{Cn(n.element,"drag","Drag layer group to the left/top/right/bottom edge of a layer group, or to another layer bar/panel (including in another Neuroglancer window)"),Ib(r,{manager:this.layerSpecification,layers:this.layerManager.managedLayers,layoutSpec:this.layout.toJSON()});const o=()=>{_n&&_n.viewer===this&&(_n=void 0),this.unregisterDisposer(o)};_n={viewer:this,disposer:o},this.registerDisposer(o);const a=this.toJSON();a.layers=void 0,r.dataTransfer.setData(fh,JSON.stringify(a)),n.element.style.backgroundColor="black",setTimeout(()=>{n.element.style.backgroundColor=""},0)}),n.element.addEventListener("dragend",()=>{kt(s,"drag"),Cl(),_n!==void 0&&_n.viewer===this&&_n.disposer()}),this.element.insertBefore(s,this.element.firstChild)}}disposed(){Me(this.element);const{layerPanel:e}=this;e!==void 0&&(e.dispose(),this.layerPanel=void 0),super.disposed()}}/** + * @license + * Copyright 2017 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const _b=Symbol("layoutComponentContainer");class tr extends T.O8{constructor(e,t,n){super(),this.viewer=e,this.parent=n,this.changed=new j.IY,this.flex=new _.DN(1,f.Mo),this.element=document.createElement("div");const{element:s}=this;s.style.display="flex",s.style.flex="1",s.style.position="relative",s.style.alignItems="stretch",s[_b]=this,this.flex.changed.add(()=>{s.style.flexGrow=""+this.flex.value,this.changed.dispatch()}),this.setSpecification(t);const r=[],o=l=>{const c=document.createElement("div");c.className="neuroglancer-layout-split-drop-zone";let d;switch(c.style[l]="0",l){case"left":case"right":d="row",c.style.width="10px",c.style.height="100%";break;case"top":case"bottom":d="column",c.style.height="10px",c.style.width="100%";break}c.style.display="none",r.push({element:c,direction:d,orientation:l}),s.appendChild(c),Bb(c,this.viewer.layerSpecification,()=>this.split(l).newContainer.component,d==="row"?"column":"row")};o("left"),o("right"),o("top"),o("bottom");let a=!1;s.addEventListener("dragenter",l=>{if(!a&&wl(l)!==void 0){a=!0;for(const{element:c,direction:d,orientation:u}of r){if(n!==void 0&&d===n.direction&&((u==="left"||u==="top")&&n.get(0)!==this||(u==="bottom"||u==="right")&&n.get(n.length-1)!==this))continue;const{component:h}=this;h instanceof El&&h.direction===d||(c.style.display="block")}}},!0),s.addEventListener("drop",l=>{if(a){a=!1;for(const{element:c}of r)c.style.display="none"}},!0),s.addEventListener("dragleave",l=>{const{relatedTarget:c}=l;if(a&&!(c instanceof HTMLElement&&this.element.contains(c))){a=!1;for(const{element:d}of r)d.style.display="none"}},!0)}unsetComponent(){const e=this.componentValue;e!==void 0&&(e.changed.remove(this.changed.dispatch),this.element.removeChild(e.element),e.dispose())}get component(){return this.componentValue}setComponent(e){if(this.unsetComponent(),this.componentValue=e,e.changed.add(this.changed.dispatch),this.element.appendChild(e.element),e instanceof ro){const{layerManager:t}=e,n=e.registerCancellable((0,Fe.A)(()=>{t.managedLayers.length===0&&this.dispose()},0));e.registerDisposer(t.layersChanged.add(()=>{t.managedLayers.length===0&&n()})),n()}else if(e instanceof El){const t=e.registerCancellable((0,Fe.A)(()=>{const{length:n}=e;if(n===0&&this.parent!==void 0)this.dispose();else if(n===1){const s=e.get(0).component;let r;if(this.parent===void 0&&s instanceof ro){r=s.layout.specification.toJSON(),s.viewerNavigationState.copyToParent();const o=s.layerManager.managedLayers,a=new Set(o),{layerSpecification:l}=s;l.rootLayers.filter(u=>a.has(u)||u.archived);const c=[],{managedLayers:d}=l.rootLayers;for(let u=0,h=d.length;u{e.length<2&&t()})),t()}this.changed.dispatch()}toJSON(){const e=this.component.toJSON();return this.parent instanceof El&&(e.flex=this.flex.toJSON()),e}setSpecification(e){this.setComponent(R_(this,e)),this.flex.value=(0,f.MM)(e,"flex",f.Mo,1)}static getFromElement(e){return e[_b]}disposed(){this.unsetComponent(),this.componentValue=void 0,super.disposed()}split(e){const t={type:"viewer"},{parent:n}=this;if(n!==void 0){if(e==="left"&&n.direction==="row"||e==="top"&&n.direction==="column")return{newContainer:n.insertChild(t,this),existingContainer:this};if(e==="right"&&n.direction==="row"||e==="bottom"&&n.direction==="column")return{newContainer:n.insertChild(t),existingContainer:this}}let s;const r=this.component;r instanceof gh?s=r.layerGroupViewer.toJSON():s=r.toJSON();let o,a;const l=e==="left"||e==="right"?"row":"column";switch(e){case"left":case"top":o={type:l,children:[t,s]},a=0;break;case"right":case"bottom":o={type:l,children:[s,t]},a=1;break}this.setSpecification(o);const c=this.component;return{newContainer:c.get(a),existingContainer:c.get(1-a)}}}function Vb(i){return{mouseState:i.mouseState,showAxisLines:i.showAxisLines,wireFrame:i.wireFrame,enableAdaptiveDownsampling:i.enableAdaptiveDownsampling,showScaleBar:i.showScaleBar,scaleBarOptions:i.scaleBarOptions,showPerspectiveSliceViews:i.showPerspectiveSliceViews,inputEventBindings:i.inputEventBindings,visibility:i.visibility,selectedLayer:i.selectedLayer,visibleLayerRoles:i.visibleLayerRoles,navigationState:i.navigationState.addRef(),perspectiveNavigationState:i.perspectiveNavigationState.addRef(),velocity:i.velocity.addRef(),crossSectionBackgroundColor:i.crossSectionBackgroundColor,perspectiveViewBackgroundColor:i.perspectiveViewBackgroundColor}}class gh extends T.O8{constructor(e,t,n){super(),this.element=e,this.layerGroupViewer=this.registerDisposer(new ro(e,{display:n.display,layerSpecification:n.layerSpecification.addRef(),...Vb(n)},{showLayerPanel:n.uiControlVisibility.showLayerPanel,showViewerMenu:!1,showLayerHoverValues:n.uiControlVisibility.showLayerHoverValues})),this.layerGroupViewer.layout.restoreState(t)}toJSON(){return this.layerGroupViewer.layout.specification.toJSON()}get changed(){return this.layerGroupViewer.layout.changed}}function Bb(i,e,t,n){i.addEventListener("dragenter",s=>{wl(s)!==void 0&&i.classList.add("neuroglancer-drag-over")}),i.addEventListener("dragleave",()=>{kt(i,"drop"),i.classList.remove("neuroglancer-drag-over")}),i.addEventListener("dragover",s=>{const r=(o,a)=>{o.dropEffectMessage&&(a+=` (${o.dropEffectMessage})`),Cn(i,"drop",a),s.stopPropagation(),s.preventDefault()};if(Ob(s)){const o=D_(s,e);dh(s,o.dropEffect),r(o,`Drop to ${o.dropEffect} layer group as new ${n}`);return}if(wl(s)!==void 0){const o=w_(s,e,!1,!0);r(o,`Drop to ${o.dropEffect} layer as new ${n}`);return}}),i.addEventListener("drop",s=>{i.classList.remove("neuroglancer-drag-over"),kt(i,"drop");let r,o;if(Ob(s)){s.stopPropagation();try{o=JSON.parse(s.dataTransfer.getData(fh))}catch{return}if(r=hh(s,e,{forceCopy:!1,newTarget:!0}),r===void 0)return}else{if(r=hh(s,e,{forceCopy:uh()==="copy",newTarget:!0}),r===void 0)return;o=r.layoutSpec}if(!r.initializeExternalLayers(s)){if(!r.moveSupported)for(const c of r.layers.keys())c.dispose();return}s.preventDefault();const a=s.dataTransfer.dropEffect=uh();Cl(a);const l=t();r.updateArchiveStates(s);for(const c of r.layers.keys())l.layerSpecification.add(c);try{l.restoreState(o)}catch{l.layout.reset()}})}class El extends T.O8{constructor(e,t,n,s){super(),this.element=e,this.direction=t,this.container=s,this.changed=new j.IY,e.classList.add("neuroglancer-stack-layout"),e.classList.add(`neuroglancer-stack-layout-${t}`),e.style.display="flex",e.style.flexDirection=t,e.appendChild(this.makeDropPlaceholder(this));for(const r of n)this.insertChild(r)}get length(){return(this.element.childElementCount-1)/2}makeDropPlaceholder(e){const t=document.createElement("div");return t.className="neuroglancer-stack-layout-drop-placeholder",Bb(t,this.viewer.layerSpecification,()=>{const n=t.nextElementSibling;let s;return n!==null&&(s=tr.getFromElement(n)),this.insertChild({type:"viewer",layers:[]},s).component},this.direction==="row"?"column":"row"),e.registerDisposer(()=>{at(t)}),t.addEventListener("pointerdown",n=>{if("button"in n&&n.button!==0)return;const s=t.nextElementSibling;if(s===null)return;const r=tr.getFromElement(s),o=t.previousElementSibling;if(o===null)return;const a=tr.getFromElement(o);n.preventDefault();const l=()=>{Cn(t,"drag",`Drag to resize, current ${Ji[this.direction]} ratio is ${a.flex.value} : ${r.flex.value}`)};l(),zt(n,c=>{const d=a.element.getBoundingClientRect(),u=r.element.getBoundingClientRect(),h=Math.max(.1,Math.min(.9,this.direction==="column"?(c.clientY-d.top)/(u.bottom-d.top):(c.clientX-d.left)/(u.right-d.left))),p=Number(a.flex.value)+Number(r.flex.value);a.flex.value=Math.round(h*p*100)/100,r.flex.value=Math.round((1-h)*p*100)/100,l()},()=>{kt(t,"drag")})}),t}get viewer(){return this.container.viewer}get(e){return tr.getFromElement(this.element.children[e*2+1])}insertChild(e,t){const n=new tr(this.viewer,e,this),s=this.makeDropPlaceholder(n);n.element.classList.add("neuroglancer-stack-layout-child"),n.registerDisposer(n.changed.add(this.changed.dispatch)),n.registerDisposer(()=>{this.element.removeChild(n.element),this.changed.dispatch()});const r=t!==void 0?t.element:null;return this.element.insertBefore(n.element,r),this.element.insertBefore(s,r),this.changed.dispatch(),n}disposed(){this.clear(),super.disposed()}clear(){for(;this.length!==0;)this.get(0).dispose()}*[Symbol.iterator](){const{length:e}=this;for(let t=0;te.toJSON())}}}function R_(i,e){const t=document.createElement("div");if(t.style.flex="1",t.style.width="0px",typeof e=="string"){if(i.parent!==void 0)throw new Error(`Invalid layout component specification: ${JSON.stringify(e)}`);return new gh(t,e,i.viewer)}(0,f.Rf)(e);const n=(0,f.cQ)(e,"type",f.zr);switch(n){case"row":case"column":return new El(t,n,(0,f.cQ)(e,"children",s=>{const r=(0,f.$v)(s,o=>o);if(i.parent===void 0&&r.length===0)throw new Error("Stack layout requires at least one child.");return r}),i);case"viewer":{const s=i.viewer,r=new zg(s.layerSpecification.addRef()),o=new ro(t,{display:s.display,layerSpecification:r,...Vb(s)},{showLayerPanel:s.uiControlVisibility.showLayerPanel,showViewerMenu:!0,showLayerHoverValues:s.uiControlVisibility.showLayerHoverValues});try{o.restoreState(e)}catch(a){throw o.dispose(),a}return o}default:return new gh(t,e,i.viewer)}}class k_ extends T.O8{constructor(e,t){super(),this.viewer=e,this.defaultSpecification=t,this.container=this.registerDisposer(new tr(this.viewer,this.defaultSpecification,void 0))}get changed(){return this.container.changed}get element(){return this.container.element}reset(){this.container.setSpecification(this.defaultSpecification)}restoreState(e){this.container.setSpecification(e)}disposed(){super.disposed()}toJSON(){return this.container.toJSON()}}var P_=G(1152),A_=G(5093);/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const M_=Ae.fromObject({escape:{action:"cancel"}});class Fb extends T.O8{constructor(e){super(),this.layer=e,this.element=document.createElement("input");const{element:t}=this;t.classList.add("neuroglancer-layer-side-panel-name"),t.spellcheck=!1,t.autocomplete="off";const n=this.registerDisposer(new yn(t,M_));n.allShortcutsAreGlobal=!0,Z(t,"cancel",s=>{this.updateView(),t.blur(),s.stopPropagation(),s.preventDefault()}),t.title="Rename layer",this.registerDisposer(e.layerChanged.add(()=>this.updateView())),t.addEventListener("change",()=>this.updateModel()),t.addEventListener("blur",()=>this.updateModel()),this.updateView()}updateView(){this.element.value=this.layer.name}updateModel(){Jg(this.layer,this.element.value)}}class N_ extends T.O8{constructor(e){super(),this.layer=e,this.element=document.createElement("select"),this.measureElement=document.createElement("div");const{element:t,measureElement:n}=this;t.classList.add("neuroglancer-layer-side-panel-type"),n.classList.add("neuroglancer-layer-side-panel-type-measure"),t.title="Change layer type",document.body.appendChild(n);for(const[s,r]of Mr){if(r.type!==s)continue;const o=document.createElement("option");o.textContent=r.typeAbbreviation,o.value=s,t.appendChild(o)}t.addEventListener("change",()=>{const s=t.value,r=Mr.get(s);Zc(this.layer.managedLayer,r)}),this.updateView()}updateView(){const e=this.layer.type,{element:t,measureElement:n}=this;n.textContent=this.layer.constructor.typeAbbreviation,t.value=e,t.style.width=`${n.offsetWidth}px`}disposed(){this.measureElement.remove()}}class Tl extends ji{constructor(e,t){super(e,t.location),this.panelState=t;const n=this.layer=t.layer,{element:s}=this,{titleBar:r}=this.addTitleBar({});r.classList.add("neuroglancer-layer-side-panel-title"),r.appendChild(this.registerDisposer(new N_(n)).element),r.appendChild(this.registerDisposer(new Fb(n.managedLayer)).element),this.registerDisposer((0,_.W1)(l=>{s.dataset.neuroglancerLayerVisible=l.toString()},{get value(){return n.managedLayer.visible},changed:n.managedLayer.layerChanged}));const o=this.registerDisposer(new rn({get value(){return n.managedLayer.pickEnabled},set value(l){n.managedLayer.pickEnabled=l},changed:n.managedLayer.layerChanged},{svg:A_,enableTitle:"Spatial object selection: disabled",disableTitle:"Spatial object selection: enabled"}));this.registerDisposer(new en({get value(){return n.managedLayer.supportsPickOption},changed:n.managedLayer.layerChanged},o.element)),r.appendChild(o.element);const a={get value(){return t!==n.panels.panels[0]},set value(l){l?t.pin():t.unpin()},changed:n.manager.root.layerManager.layersChanged};r.appendChild(this.registerDisposer(new rn(a,{text:"\u{1F4CC}\uFE0E",enableTitle:"Pin panel to this layer",disableTitle:"Unpin panel to this layer"})).element),this.registerDisposer((0,_.W1)(l=>{s.dataset.neuroglancerLayerPanelPinned=l.toString()},a)),r.appendChild(Mn({title:"Delete layer",onClick:()=>{Ms(this.layer.managedLayer)}})),this.tabView=new gx({makeTab:l=>n.tabs.options.get(l).getter(),selectedTab:t.selectedTab,tabs:this.registerDisposer(new _.pz({get value(){return t.tabs.map(l=>{const{label:c,hidden:d}=n.tabs.options.get(l);return{id:l,label:c,hidden:d?.value||!1}})},changed:t.tabsChanged})),handleTabElement:(l,c)=>{c.draggable=!0,c.addEventListener("dragstart",d=>{d.stopPropagation(),d.dataTransfer.setData("neuroglancer-side-panel","");let u="Drag tab to dock as new panel to the left/right/top/bottom of another panel";t.panels.panels.find(p=>p!==t&&p.location.visible)&&(u+=`, or move tab to other ${JSON.stringify(n.managedLayer.name)} panel`),Cn(c,"drag",u),this.sidePanelManager.startDrag({dropAsNewPanel:p=>{this.panelState.splitOffTab(l,{...Tg,...p})},canDropAsTabs:p=>p instanceof Tl&&p.layer===this.layer&&p!==this?1:0,dropAsTab:p=>{this.panelState.moveTabTo(l,p.panelState)}},d)}),c.addEventListener("dragend",d=>{kt(c,"drag"),this.sidePanelManager.endDrag()})}},this.visibility),this.tabView.element.style.flex="1",this.tabView.element.classList.add("neuroglancer-layer-side-panel-tab-view"),this.tabView.element.style.position="relative",this.tabView.element.appendChild(this.makeTabDropZone()),this.addBody(this.tabView.element),this.registerDisposer(t.tabsChanged.add(()=>{t.tabs.length===0&&(this.location.visible=!1)}))}makeDragSource(){return{...super.makeDragSource(),canDropAsTabs:e=>e instanceof Tl&&e.layer===this.layer&&e!==this?this.panelState.tabs.length:0,dropAsTab:e=>{this.panelState.mergeInto(e.panelState)}}}makeTabDropZone(){const e=document.createElement("div");return e.className="neuroglancer-side-panel-drop-zone",e.style.position="absolute",e.style.left="20px",e.style.right="20px",e.style.bottom="20px",e.style.top="20px",e.addEventListener("dragenter",t=>{const{dragSource:n}=this.sidePanelManager,s=n?.canDropAsTabs?.(this);s&&(e.classList.add(_s),Cn(e,"drop",`Move ${s} ${s===1?"tab":"tabs"} to this panel`),t.preventDefault())}),e.addEventListener("dragleave",()=>{kt(e,"drop"),e.classList.remove(_s)}),e.addEventListener("dragover",t=>{const{dragSource:n}=this.sidePanelManager;n?.canDropAsTabs?.(this)&&t.preventDefault()}),e.addEventListener("drop",t=>{kt(e,"drop");const{dragSource:n}=this.sidePanelManager;n?.canDropAsTabs?.(this)&&(e.classList.remove(_s),n.dropAsTab(this),t.preventDefault(),t.stopPropagation())}),e}}class O_ extends T.O8{constructor(e,t){super(),this.sidePanelManager=e,this.selectedLayerState=t,this.layerSidePanels=new Map,this.generation=0,this.layersNeedUpdate=!0;const n=()=>{this.layersNeedUpdate=!0,this.sidePanelManager.display.scheduleRedraw()};this.registerDisposer(t.changed.add(n)),this.registerDisposer(t.layerManager.layersChanged.add(n)),this.registerDisposer(e.beforeRender.add(()=>this.update()))}getSelectedUserLayer(){return this.selectedLayerState.layer?.layer??void 0}update(){if(!this.layersNeedUpdate)return;const{layerManager:e}=this.selectedLayerState,t=++this.generation;this.layersNeedUpdate=!1;const{layerSidePanels:n}=this,s=r=>{let o=n.get(r);o===void 0?(o={generation:t,unregister:this.sidePanelManager.registerPanel({location:r.location,makePanel:()=>new Tl(this.sidePanelManager,r)})},n.set(r,o)):o.generation=t};{const r=this.getSelectedUserLayer(),{location:o}=this.selectedLayerState;if(r===void 0||!o.visible)this.placeholderSelectedLayerPanel===void 0&&(this.placeholderSelectedLayerPanel=this.sidePanelManager.registerPanel({location:o,makePanel:()=>new ji(this.sidePanelManager,o)}));else{this.placeholderSelectedLayerPanel?.(),this.placeholderSelectedLayerPanel=void 0;const a=r.panels.panels[0];a.location.value=o.value,s(a)}}for(const r of e.managedLayers){const o=r.layer;if(o===null)continue;const{panels:a}=o.panels;for(let l=1,c=a.length;l{this.layer.setVisible(!1)}}),s=Ne({svg:_m,title:"Show layer",onClick:()=>{this.layer.setVisible(!0)}});t.appendChild(s),t.appendChild(n);const r=()=>{const o=this.layer.visible;n.style.display=o?"":"none",s.style.display=o?"none":""};r(),this.registerDisposer(e.layerChanged.add(r))}}function F_(i){const{selectedLayer:e}=i.manager.root,t=new rn({get value(){return e.layer===i&&e.visible},set value(n){n?(e.layer=i,e.visible=!0):e.visible=!1},changed:e.changed},{backgroundScheme:"dark",enableTitle:"Show layer side panel",disableTitle:"Hide layer side panel",svg:rb});return t.element.classList.add("neuroglancer-layer-list-panel-item-controls"),t}class U_ extends T.O8{constructor(e,t){super(),this.panel=e,this.layer=t,this.element=document.createElement("div"),this.numberElement=document.createElement("div"),this.generation=-1;const{element:n,numberElement:s}=this;n.classList.add("neuroglancer-layer-list-panel-item"),s.classList.add("neuroglancer-layer-list-panel-item-number"),n.appendChild(this.registerDisposer(new pn({get value(){return!t.archived},set value(o){t.setArchived(!o)},changed:t.layerChanged},{enableTitle:"Archive layer (disable and remove from layer groups)",disableTitle:"Unarchive layer (enable and add to all layer groups)"})).element),n.appendChild(s),n.appendChild(this.registerDisposer(new B_(t)).element),n.appendChild(this.registerDisposer(new Fb(t)).element),n.appendChild(this.registerDisposer(F_(t)).element);const r=Mn({title:"Delete layer",onClick:()=>{Ms(this.layer)}});r.classList.add("neuroglancer-layer-list-panel-item-delete"),n.appendChild(r),Ab(e,n,t,{isLayerListPanel:!0,getLayoutSpec:()=>{}}),xl(e,n,t,!0),n.addEventListener("click",o=>{o.ctrlKey?(e.selectedLayer.toggle(t),o.preventDefault()):o.altKey&&(t.pickEnabled=!t.pickEnabled,o.preventDefault())}),n.addEventListener("contextmenu",o=>{e.selectedLayer.toggle(t),o.stopPropagation(),o.preventDefault()})}}class $_ extends ji{constructor(e,t,n){super(e,n.location),this.manager=t,this.state=n,this.items=new Map,this.itemContainer=document.createElement("div"),this.layerDropZone=document.createElement("div"),this.dragEnterCount=0,this.generation=-1;const{itemContainer:s,layerDropZone:r}=this,{titleElement:o}=this.addTitleBar({title:""});this.titleElement=o,s.classList.add("neuroglancer-layer-list-panel-items"),this.addBody(s),r.style.flex="1";const a=this.registerCancellable((0,Qe.t)(()=>this.render()));this.visibility.changed.add(a),this.registerDisposer(this.layerManager.layersChanged.add(a)),this.registerDisposer(this.selectedLayer.changed.add(a)),Mb(this),xl(this,r,void 0,!0),this.render()}get layerManager(){return this.manager.layerManager}get selectedLayer(){return this.manager.selectedLayer}render(){const e=this,t=this.selectedLayer.layer,n=++this.generation;let s=0,r=0,o=0;this.layerManager.updateNonArchivedLayerIndices();function*a(){const{items:c}=e;let d=0;for(const h of e.layerManager.managedLayers)h.archived||++d;const u=`${(d+1).toString().length}ch`;for(const h of e.layerManager.managedLayers){h.visible?++s:h.archived?++o:++r;let p=c.get(h);p===void 0&&(p=e.registerDisposer(new U_(e,h)),c.set(h,p)),p.generation=n;const{nonArchivedLayerIndex:m}=h;p.numberElement.style.width=u,m===-1?p.numberElement.style.visibility="hidden":(p.numberElement.style.visibility="",p.numberElement.textContent=`${m+1}`),p.element.dataset.selected=(h===t).toString(),p.element.dataset.archived=h.archived.toString(),yield p.element}for(const[h,p]of c)n!==p.generation&&(c.delete(h),e.unregisterDisposer(p),p.dispose());yield e.layerDropZone}nn(this.itemContainer,a());let l="Layers";if(s||r||o){l+=" (";let c="";s+r&&(l+=`${s}/${r+s} visible`,c=", "),o&&(l+=`${c}${o} archived`),l+=")"}this.titleElement.textContent=l}}class G_ extends T.O8{constructor(e){super(),this.layerManager=e,this.element=document.createElement("div");const t=this.registerCancellable((0,Qe.t)(()=>this.render()));this.registerDisposer(e.layersChanged.add(t)),this.render()}render(){let e=0;const{managedLayers:t}=this.layerManager;for(const s of t)s.archived&&++e;const{element:n}=this;if(e!==0){const s=t.length;n.textContent=`${s-e}/${s}`}else n.textContent=""}}var D2=G(6792),I2=G(8948),L2=G(1274),R2=G(795);/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const z_=100;class W_ extends Jr{constructor(e){super(),this.viewer=e,this.parsedValue=null,this.debouncedValueUpdater=(0,Fe.A)(()=>{const r=this.textEditor.getValue();try{const o=JSON.parse(r);this.parsedValue=o,this.applyButton.disabled=!1,this.textEditor.setOption("lint",void 0)}catch(o){this.parsedValue=null,this.applyButton.disabled=!0;let a=0,l=0,c="Unknown parse error";if(o instanceof Error){const d=o.message.match(/^((?:.|\n)*) in JSON at position ([0-9]+)$/);if(d!==null){c=d[1];const u=parseInt(d[2],10),p=r.substring(0,u).split(` +`);a=p.length-1,l=p[p.length-1].length}else c=o.message}this.textEditor.setOption("lint",{getAnnotations:()=>[{message:c,severity:"error",from:Ti().Pos(a,l)}]})}},z_),this.content.classList.add("neuroglancer-state-editor");const t=this.applyButton=document.createElement("button");t.textContent="Apply changes",this.content.appendChild(t),t.addEventListener("click",()=>this.applyChanges()),t.disabled=!0;const n=this.closeButton=document.createElement("button");n.classList.add("close-button"),n.textContent="Close",this.content.appendChild(n),n.addEventListener("click",()=>this.dispose());const s=this.downloadButton=document.createElement("button");s.textContent="Download",s.title="Download state as a JSON file",this.content.appendChild(s),s.addEventListener("click",()=>this.downloadState()),this.textEditor=Ti()(r=>{},{value:"",mode:{name:"javascript",json:!0},foldGutter:!0,gutters:["CodeMirror-lint-markers","CodeMirror-foldgutter"]}),this.updateView(),this.textEditor.on("change",()=>{this.debouncedValueUpdater()}),this.content.appendChild(this.textEditor.getWrapperElement()),this.textEditor.refresh()}downloadState(){const e=document.createElement("a"),t=new Blob([this.getJson()],{type:"text/json"}),n=URL.createObjectURL(t);e.href=n,e.download="state.json",e.click(),document.body.removeChild(e)}applyChanges(){this.parsedValue!==null&&(this.viewer.state.reset(),this.viewer.state.restoreState(this.parsedValue)),this.applyButton.disabled=!0}updateView(){this.textEditor.setValue(this.getJson()),this.textEditor.execCommand("foldAll"),this.textEditor.execCommand("unfold")}getJson(){return JSON.stringify(Lo(this.viewer.state).value,null," ")}}/** + * @license + * Copyright 2019 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const H_={side:"bottom",size:100,minSize:50,row:0,col:0,flex:1,visible:!1};class J_{constructor(){this.location=new Si(H_)}get changed(){return this.location.changed}restoreState(e){this.location.restoreState(e)}reset(){this.location.reset()}toJSON(){return(0,f.Zu)(this.location.toJSON())}}function j_(i){const e=new Map;function t(n,s){if(n==null||typeof n!="object"){e.set(s,""+n);return}for(const r of Object.keys(n))t(n[r],s+"."+r)}return t(i,""),e}function Y_(i){const e=new Set;e.add(".type");const t=new Set;function n(s,r){for(const o of e)if(i[s].get(o)!==i[r].get(o))return!0;return!1}for(let s=0,r=i.length;s0;){let a=o,l;for(const c of t){if(e.has(c))continue;const d=[];for(const u of o)i[u].get(c)===i[s].get(c)&&d.push(u);if(d.lengthQ_(n,t))}const X_=1e3,mh=[{label:"Visible chunks/T",key:"visibleChunksTotal",getter:i=>{let e=0;for(let t=0;ti[Pi(Ue.DOWNLOADING,ri.VISIBLE)*Un+oi.numChunks]},{label:"Visible chunks/M",key:"visibleChunksSystemMemory",getter:i=>i[Pi(Ue.SYSTEM_MEMORY,ri.VISIBLE)*Un+oi.numChunks]+i[Pi(Ue.SYSTEM_MEMORY_WORKER,ri.VISIBLE)*Un+oi.numChunks]},{label:"Visible chunks/G",key:"visibleChunksGpuMemory",getter:i=>i[Pi(Ue.GPU_MEMORY,ri.VISIBLE)*Un+oi.numChunks]},{label:"Visible chunks/F",key:"visibleChunksFailed",getter:i=>i[Pi(Ue.FAILED,ri.VISIBLE)*Un+oi.numChunks]},{label:"Visible memory",key:"visibleGpuMemory",getter:i=>i[Pi(Ue.GPU_MEMORY,ri.VISIBLE)*Un+oi.gpuMemoryBytes]},{label:"Download latency",key:"downloadLatency",getter:i=>i[tp(ec.totalTime)]/i[tp(ec.totalChunks)]}];class Z_ extends ji{constructor(e,t,n){super(e,n.location),this.chunkQueueManager=t,this.displayState=n,this.data=void 0,this.requestDataTimerId=-1,this.dataRequested=!1,this.body=document.createElement("div"),this.debouncedUpdateView=this.registerCancellable((0,Fe.A)(()=>this.updateView(),0));const{body:s}=this;s.classList.add("neuroglancer-statistics-panel-body"),this.addTitleBar({title:"Chunk statistics"}),this.addBody(s),this.requestData()}disposed(){window.clearTimeout(this.requestDataTimerId),super.disposed()}requestData(){if(this.dataRequested)return;const{chunkQueueManager:e}=this;this.dataRequested=!0,e.getStatistics().then(t=>{this.dataRequested=!1,this.data=t,this.debouncedUpdateView(),this.requestDataTimerId=window.setTimeout(()=>{this.requestDataTimerId=-1,this.requestData()},X_)})}updateView(){const{data:e}=this;if(e===void 0)return;const t=document.createElement("table"),n=[];for(const[a,l]of e){const c=[a];for(const{getter:d}of mh)c.push(d(l));n.push(c)}const s=q_(n.map(a=>K_(a[0]))),r=new Map;s.forEach((a,l)=>{r.set(n[l][0],a)});{const a=document.createElement("thead");let l=document.createElement("tr");a.appendChild(l);const c=u=>{const h=document.createElement("td");h.textContent=u,l.appendChild(h)};c("Name");let d;for(const{label:u}of mh){const h=u.indexOf("/");let p=u;if(h!==-1){if(p=u.substring(0,h),p===d){++l.lastElementChild.colSpan;continue}d=p}c(p)}l=document.createElement("tr"),a.appendChild(l);{const u=document.createElement("td");l.appendChild(u)}for(const{label:u}of mh){const h=u.indexOf("/");let p="";h!==-1&&(p=u.substring(h+1));const m=document.createElement("td");m.textContent=p,l.appendChild(m)}t.appendChild(a)}const o=document.createElement("tbody");for(const[a,...l]of n){const c=document.createElement("tr"),d=u=>{const h=document.createElement("td");h.textContent=u,c.appendChild(h)};d(r.get(a));for(const u of l)d(""+u);o.appendChild(c)}t.appendChild(o),Me(this.body),this.body.appendChild(t)}}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const eV={...Ui,side:"left",row:2};class tV{constructor(){this.location=new Si(eV)}get changed(){return this.location.changed}toJSON(){return(0,f.Zu)(this.location.toJSON())}reset(){this.location.reset()}restoreState(e){this.location.restoreState(e)}}class nV extends ji{constructor(e,t,n){super(e,t.location),this.addTitleBar({title:"Settings"});const s=document.createElement("div");s.classList.add("neuroglancer-settings-body");const r=document.createElement("div");r.classList.add("neuroglancer-settings-scroll-container"),s.appendChild(r),this.addBody(s);{const c=this.registerDisposer(new lm(n.title));c.element.placeholder="Title",c.element.classList.add("neuroglancer-settings-title"),r.appendChild(c.element)}const o=(c,d)=>{const u=this.registerDisposer(new Ic(d,{label:c}));u.element.classList.add("neuroglancer-settings-limit-widget"),r.appendChild(u.element)};o("GPU memory limit",n.chunkQueueManager.capacities.gpuMemory.sizeLimit),o("System memory limit",n.chunkQueueManager.capacities.systemMemory.sizeLimit),o("Concurrent chunk requests",n.chunkQueueManager.capacities.download.itemLimit);const a=(c,d)=>{const u=document.createElement("label");u.textContent=c;const h=this.registerDisposer(new pn(d));u.appendChild(h.element),r.appendChild(u)};a("Show axis lines",n.showAxisLines),a("Show scale bar",n.showScaleBar),a("Show cross sections in 3-d",n.showPerspectiveSliceViews),a("Show default annotations",n.showDefaultAnnotations),a("Show chunk statistics",n.statisticsDisplayState.location.watchableVisible),a("Wire frame rendering",n.wireFrame),a("Enable prefetching",n.chunkQueueManager.enablePrefetch),a("Enable adaptive downsampling",n.enableAdaptiveDownsampling);const l=(c,d)=>{const u=document.createElement("label");u.textContent=c;const h=this.registerDisposer(new hi(d));u.appendChild(h.element),r.appendChild(u)};l("Cross-section background",n.crossSectionBackgroundColor),l("Projection background",n.perspectiveViewBackgroundColor)}}/** + * @license + * Copyright 2018 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class iV extends T.O8{constructor(e,t){super(),this.selectedLayer=e,this.toolBinder=t,this.element=document.createElement("div"),this.viewContext=void 0,this.updateView=this.registerCancellable((0,Qe.t)(()=>{let{viewContext:s}=this;s!==void 0&&(this.unregisterDisposer(s),s.dispose()),this.viewContext=s=this.registerDisposer(new T.O8),Me(this.element);const{selectedTool:r}=this;r!==void 0&&this.element.appendChild(this.makeWidget(s,r));const o=Array.from(this.toolBinder.bindings);o.sort(([a],[l])=>(0,kr.e)(a,l));for(const[,a]of o)this.element.appendChild(this.makeWidget(s,a))}));const{element:n}=this;n.className="neuroglancer-annotation-tool-status",this.registerDisposer(e.changed.add(()=>this.selectedLayerChanged())),this.registerDisposer(t.changed.add(this.updateView)),this.registerDisposer(this.selectedLayer.layerManager.layersChanged.add(this.updateView)),this.selectedLayerChanged()}get selectedTool(){const e=this.selectedLayer.layer;if(e===void 0)return;const t=e.layer;if(t!==null)return t.tool.value}selectedLayerChanged(){const{unbindPreviousLayer:e}=this;e!==void 0&&e();const t=this.selectedLayer.layer;t!==void 0&&(this.unbindPreviousLayer=t.specificationChanged.add(()=>{this.updateView()})),this.updateView()}disposed(){const{unbindPreviousLayer:e}=this;e!==void 0&&e(),this.unbindPreviousLayer=void 0}makeWidget(e,t){const n=document.createElement("div");n.title="dblclick \u2192 unbind",t instanceof Oo&&(n.title+=", click \u2192 bind key"),n.className="neuroglancer-annotation-tool-status-widget";const s=document.createElement("div");s.className="neuroglancer-annotation-tool-status-widget-layer-number";const r=document.createElement("div");if(r.className="neuroglancer-annotation-tool-status-widget-description",r.textContent=t.description,n.addEventListener("dblclick",()=>{t instanceof Df?t.layer.tool.value=void 0:this.toolBinder.set(t.keyBinding,void 0)}),t instanceof Oo){const a=document.createElement("div");a.className="neuroglancer-annotation-tool-status-widget-key",a.textContent=t.keyBinding,n.appendChild(a),Rf(e,n,l=>t.localBinder.set(l,t.addRef()))}const o=t.context;if(o instanceof Rn){const{managedLayer:a}=o;a.manager.rootLayers.updateNonArchivedLayerIndices();const l=a.nonArchivedLayerIndex;s.textContent=(l+1).toString(),n.appendChild(s)}return n.appendChild(r),n}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */class sV extends T.O8{constructor(e,t){super(),this.gl=e,this.frameNumberCounter=t,this.worker=new Worker(new URL(G.p+G.u(717),G.b),{type:"module"}),this.chunkQueueManager=this.registerDisposer(new Vc(new ZC(this.worker,!0),this.gl,this.frameNumberCounter,{gpuMemory:new Zo({defaultItemLimit:1e6,defaultSizeLimit:1e9}),systemMemory:new Zo({defaultItemLimit:1e7,defaultSizeLimit:2e9}),download:new Zo({defaultItemLimit:100,defaultSizeLimit:Number.POSITIVE_INFINITY}),compute:new Zo({defaultItemLimit:128,defaultSizeLimit:5e8})})),this.chunkQueueManager.registerDisposer(()=>this.worker.terminate()),this.chunkManager=this.registerDisposer(new Bc(this.chunkQueueManager))}get rpc(){return this.chunkQueueManager.rpc}}class k2 extends QO{constructor(){super(...arguments),this.global=new Ae}}const Ub=["showHelpButton","showSettingsButton","showEditStateButton","showLayerListPanelButton","showSelectionPanelButton","showLayerSidePanelButton","showLocation","showAnnotationToolStatus"],$b=[...Ub,"showLayerPanel","showLayerHoverValues"],Gb=[...$b,"showUIControls","showPanelBorders"];function rV(){return Object.fromEntries(Gb.map(i=>[i,new nt(!0)]))}function oV(i,e){for(const t of Gb){const n=e[t];n!==void 0&&(i[t].value=n)}}const aV=typeof NEUROGLANCER_OVERRIDE_DEFAULT_VIEWER_OPTIONS<"u"?NEUROGLANCER_OVERRIDE_DEFAULT_VIEWER_OPTIONS:{showLayerDialog:!0,resetStateWhenEmpty:!0};class lV extends fr{constructor(e){super(),this.viewer=e,this.add("title",e.title),this.add("dimensions",e.coordinateSpace),this.add("relativeDisplayScales",e.relativeDisplayScales),this.add("displayDimensions",e.displayDimensions),this.add("position",e.position),this.add("velocity",e.velocity),this.add("crossSectionOrientation",e.crossSectionOrientation),this.add("crossSectionScale",e.crossSectionScale),this.add("crossSectionDepth",e.crossSectionDepthRange),this.add("projectionOrientation",e.projectionOrientation),this.add("projectionScale",e.projectionScale),this.add("projectionDepth",e.projectionDepthRange),this.add("layers",e.layerSpecification),this.add("showAxisLines",e.showAxisLines),this.add("wireFrame",e.wireFrame),this.add("enableAdaptiveDownsampling",e.enableAdaptiveDownsampling),this.add("showScaleBar",e.showScaleBar),this.add("showDefaultAnnotations",e.showDefaultAnnotations),this.add("showSlices",e.showPerspectiveSliceViews),this.add("gpuMemoryLimit",e.dataContext.chunkQueueManager.capacities.gpuMemory.sizeLimit),this.add("prefetch",e.dataContext.chunkQueueManager.enablePrefetch),this.add("systemMemoryLimit",e.dataContext.chunkQueueManager.capacities.systemMemory.sizeLimit),this.add("concurrentDownloads",e.dataContext.chunkQueueManager.capacities.download.itemLimit),this.add("selectedLayer",e.selectedLayer),this.add("crossSectionBackgroundColor",e.crossSectionBackgroundColor),this.add("projectionBackgroundColor",e.perspectiveViewBackgroundColor),this.add("layout",e.layout),this.add("statistics",e.statisticsDisplayState),this.add("helpPanel",e.helpPanelState),this.add("settingsPanel",e.settingsPanelState),this.add("selection",e.selectionDetailsState),this.add("layerListPanel",e.layerListPanelState),this.add("partialViewport",e.partialViewport),this.add("selectedStateServer",e.selectedStateServer),this.add("toolBindings",e.toolBinder)}restoreState(e){const{viewer:t}=this;super.restoreState(e),(0,f.MM)(e,"navigation",n=>{(0,f.Rf)(n),(0,f.MM)(n,"pose",s=>{(0,f.Rf)(s),(0,f.MM)(s,"position",r=>{(0,f.Rf)(r),Mt(r,"voxelCoordinates",t.position),(0,f.MM)(r,"voxelSize",o=>{const a=(0,f.Xu)(new Float64Array(3),o,f.Mo);for(let l=0;l<3;++l)a[l]*=1e-9;t.coordinateSpace.value=Oe({valid:!1,names:["x","y","z"],units:["m","m","m"],scales:a})})}),Mt(s,"orientation",t.crossSectionOrientation)}),Mt(n,"zoomFactor",t.crossSectionScale.legacyJsonView)}),Mt(e,"perspectiveOrientation",t.projectionOrientation),Mt(e,"perspectiveZoom",t.projectionScale.legacyJsonView),Mt(e,"perspectiveViewBackgroundColor",t.perspectiveViewBackgroundColor)}}class zb extends T.O8{constructor(e,t={}){super(),this.display=e,this.title=new _.DN(void 0,f.zr),this.coordinateSpace=new zl,this.position=this.registerDisposer(new ui(this.coordinateSpace)),this.velocity=this.registerDisposer(new gc(this.coordinateSpace)),this.relativeDisplayScales=this.registerDisposer(new Qp(this.coordinateSpace)),this.displayDimensions=this.registerDisposer(new ef(this.coordinateSpace)),this.displayDimensionRenderInfo=this.registerDisposer(new Zp(this.relativeDisplayScales.addRef(),this.displayDimensions.addRef())),this.crossSectionOrientation=this.registerDisposer(new bs),this.crossSectionScale=this.registerDisposer(new Zw(this.displayDimensionRenderInfo.addRef())),this.projectionOrientation=this.registerDisposer(new bs),this.crossSectionDepthRange=this.registerDisposer(new Sc(-10,this.displayDimensionRenderInfo)),this.projectionDepthRange=this.registerDisposer(new Sc(-50,this.displayDimensionRenderInfo)),this.projectionScale=this.registerDisposer(new ex(this.displayDimensionRenderInfo.addRef())),this.navigationState=this.registerDisposer(new ws(new Cs(this.position.addRef(),this.displayDimensionRenderInfo.addRef(),this.crossSectionOrientation.addRef()),this.crossSectionScale.addRef(),this.crossSectionDepthRange.addRef())),this.perspectiveNavigationState=this.registerDisposer(new ws(new Cs(this.position.addRef(),this.displayDimensionRenderInfo.addRef(),this.projectionOrientation.addRef()),this.projectionScale.addRef(),this.projectionDepthRange.addRef())),this.mouseState=new OT,this.layerManager=this.registerDisposer(new Mg),this.selectedLayer=this.registerDisposer(new GT(this.layerManager.addRef())),this.showAxisLines=new nt(!0,!0),this.wireFrame=new nt(!1,!1),this.enableAdaptiveDownsampling=new nt(!0,!0),this.showScaleBar=new nt(!0,!0),this.showPerspectiveSliceViews=new nt(!0,!0),this.visibleLayerRoles=aw(),this.showDefaultAnnotations=new nt(!0,!0),this.crossSectionBackgroundColor=new q(C.eR.fromValues(.5,.5,.5)),this.perspectiveViewBackgroundColor=new q(C.eR.fromValues(0,0,0)),this.scaleBarOptions=new IO,this.partialViewport=new YC,this.statisticsDisplayState=new J_,this.helpPanelState=new p_,this.settingsPanelState=new tV,this.layerSelectedValues=this.registerDisposer(new _T(this.layerManager,this.mouseState)),this.selectionDetailsState=this.registerDisposer(new VT(this.coordinateSpace,this.layerSelectedValues)),this.selectedStateServer=new _.DN("",f.zr),this.layerListPanelState=new V_,this.resetInitiated=new j.IY,this.uiControlVisibility={},this.visible=!0,this.toolInputEventMapBinder=(p,m)=>{m.registerDisposer(this.inputEventBindings.sliceView.addParent(p,Number.POSITIVE_INFINITY)),m.registerDisposer(this.inputEventBindings.perspectiveView.addParent(p,Number.POSITIVE_INFINITY))},this.globalToolBinder=this.registerDisposer(new Rx(this.toolInputEventMapBinder)),this.toolBinder=this.registerDisposer(new Dc(this,this.globalToolBinder));const{dataContext:n=new sV(e.gl,e),visibility:s=new vt(vt.VISIBLE),inputEventBindings:r={global:new Ae,sliceView:new Ae,perspectiveView:new Ae},element:o=e.makeCanvasOverlayElement(),dataSourceProvider:a=LP({credentialsManager:Zn}),uiConfiguration:l=rV()}=t;this.visibility=s,this.inputEventBindings=r,this.element=o,this.dataSourceProvider=a,this.uiConfiguration=l,this.registerDisposer((0,_.W1)(p=>{this.display.applyWindowedViewportToElement(o,p)},this.partialViewport)),this.registerDisposer(()=>at(this.element)),this.dataContext=this.registerDisposer(n),oV(l,t);const c={...aV,...t},{resetStateWhenEmpty:d,showLayerDialog:u}=c;for(const p of $b)this.uiControlVisibility[p]=this.makeUiControlVisibilityState(p);this.registerDisposer(this.uiConfiguration.showPanelBorders.changed.add(()=>{this.updateShowBorders()})),this.showLayerDialog=u,this.resetStateWhenEmpty=d,this.layerSpecification=new HT(this.display,this.dataSourceProvider,this.layerManager,this.chunkManager,this.selectionDetailsState,this.selectedLayer,this.navigationState.coordinateSpace,this.navigationState.pose.position,this.globalToolBinder),this.registerDisposer(e.updateStarted.add(()=>{this.onUpdateDisplay()})),this.showDefaultAnnotations.changed.add(()=>{this.showDefaultAnnotations.value?this.visibleLayerRoles.add(li.DEFAULT_ANNOTATION):this.visibleLayerRoles.delete(li.DEFAULT_ANNOTATION)}),this.registerDisposer(this.navigationState.changed.add(()=>{this.handleNavigationStateChanged()}));const h=this.registerCancellable((0,Fe.A)(()=>{!this.wasDisposed&&this.layerManager.managedLayers.length===0&&this.resetStateWhenEmpty&&(this.navigationState.reset(),this.perspectiveNavigationState.pose.orientation.reset(),this.perspectiveNavigationState.zoomFactor.reset(),this.resetInitiated.dispatch(),!au&&this.showLayerDialog&&this.visibility.visible&&Qg(this.layerSpecification,this.selectedLayer))}));this.layerManager.layersChanged.add(h),h(),this.registerDisposer(this.dataContext.chunkQueueManager.visibleChunksChanged.add(()=>{this.layerSelectedValues.handleLayerChange()})),this.registerDisposer(this.dataContext.chunkQueueManager.visibleChunksChanged.add(()=>{this.visible&&e.scheduleRedraw()})),this.makeUI(),this.updateShowBorders(),this.registerActionListeners(),this.registerEventActionBindings(),this.registerDisposer(Nb(o,this.navigationState.position)),this.state=new lV(this),this.registerDisposer(new mc(this.display,this.position,this.velocity))}get chunkManager(){return this.dataContext.chunkManager}get chunkQueueManager(){return this.dataContext.chunkQueueManager}makeUiControlVisibilityState(e){const t=this.uiConfiguration.showUIControls,n=this.uiConfiguration[e];return this.registerDisposer((0,_.Kk)((s,r)=>s&&r,t,n))}get inputEventMap(){return this.inputEventBindings.global}updateShowBorders(){const{element:e}=this,t="neuroglancer-show-panel-borders";this.uiConfiguration.showPanelBorders.value?e.classList.add(t):e.classList.remove(t)}makeUI(){const e=this.element;e.classList.add("neuroglancer-viewer"),e.classList.add("neuroglancer-noselect"),e.style.display="flex",e.style.flexDirection="column";const t=document.createElement("div");t.classList.add("neuroglancer-viewer-top-row"),t.style.display="flex",t.style.flexDirection="row",t.style.alignItems="stretch";const n=this.registerDisposer(new xs(this.navigationState.position,this.layerSpecification.coordinateSpaceCombiner,{velocity:this.velocity,getToolBinder:()=>this.toolBinder}));this.registerDisposer(new en(this.uiControlVisibility.showLocation,n.element)),t.appendChild(n.element);const s=this.registerDisposer(new Bx(document.createElement("div"),this.mouseState,this.navigationState.coordinateSpace));if(s.element.style.flex="1",s.element.style.alignSelf="center",this.registerDisposer(new en(this.uiControlVisibility.showLocation,s.element)),t.appendChild(s.element),typeof NEUROGLANCER_CREDIT_LINK<"u"){let a=NEUROGLANCER_CREDIT_LINK;Array.isArray(a)||(a=[a]);for(const{url:l,text:c}of a){const d=document.createElement("a");d.style.marginRight="5px",d.href=l,d.textContent=c,d.style.fontFamily="sans-serif",d.style.color="yellow",d.target="_blank",t.appendChild(d)}}const r=this.registerDisposer(new iV(this.selectedLayer,this.globalToolBinder));if(t.appendChild(r.element),this.registerDisposer(new en(this.uiControlVisibility.showAnnotationToolStatus,r.element)),l_){const a=this.registerDisposer(new c_(this));t.appendChild(a.element)}{const{layerListPanelState:a}=this,l=this.registerDisposer(new rn(a.location.watchableVisible,{svg:lO,backgroundScheme:"dark",enableTitle:"Show layer list panel",disableTitle:"Hide layer list panel"}));l.element.insertAdjacentElement("afterbegin",this.registerDisposer(new G_(this.layerManager)).element),this.registerDisposer(new en(this.uiControlVisibility.showLayerListPanelButton,l.element)),t.appendChild(l.element)}{const{selectionDetailsState:a}=this,l=this.registerDisposer(new rn(a.location.watchableVisible,{svg:cO,backgroundScheme:"dark",enableTitle:"Show selection details panel",disableTitle:"Hide selection details panel"}));this.registerDisposer(new en(this.uiControlVisibility.showSelectionPanelButton,l.element)),t.appendChild(l.element)}{const{selectedLayer:a}=this,l=this.registerDisposer(new rn({get value(){return a.visible},set value(c){a.visible=c},changed:a.location.locationChanged},{svg:rb,backgroundScheme:"dark",enableTitle:"Show layer side panel",disableTitle:"Hide layer side panel"}));this.registerDisposer(new en(this.uiControlVisibility.showLayerSidePanelButton,l.element)),t.appendChild(l.element)}{const a=Ne({text:"{}",title:"Edit JSON state"});this.registerEventListener(a,"click",()=>{this.editJsonState()}),this.registerDisposer(new en(this.uiControlVisibility.showEditStateButton,a)),t.appendChild(a)}{const{helpPanelState:a}=this,l=this.registerDisposer(new rn(a.location.watchableVisible,{text:"?",backgroundScheme:"dark",enableTitle:"Show help panel",disableTitle:"Hide help panel"}));this.registerDisposer(new en(this.uiControlVisibility.showHelpButton,l.element)),t.appendChild(l.element)}{const{settingsPanelState:a}=this,l=this.registerDisposer(new rn(a.location.watchableVisible,{svg:dO,backgroundScheme:"dark",enableTitle:"Show settings panel",disableTitle:"Hide settings panel"}));this.registerDisposer(new en(this.uiControlVisibility.showSettingsButton,l.element)),t.appendChild(l.element)}this.registerDisposer(new en((0,_.Kk)((...a)=>a.reduce((l,c)=>l||c,!1),...Ub.map(a=>this.uiControlVisibility[a])),t)),e.appendChild(t),this.layout=this.registerDisposer(new k_(this,"4panel")),this.sidePanelManager=this.registerDisposer(new ND(this.display,this.layout.element,this.visibility)),this.registerDisposer(this.sidePanelManager.registerPanel({location:this.layerListPanelState.location,makePanel:()=>new $_(this.sidePanelManager,this.layerSpecification,this.layerListPanelState)})),this.registerDisposer(new O_(this.sidePanelManager,this.selectedLayer.addRef())),this.registerDisposer(this.sidePanelManager.registerPanel({location:this.selectionDetailsState.location,makePanel:()=>new OD(this.sidePanelManager,this.selectionDetailsState,this.layerSpecification,this.selectedLayer)})),e.appendChild(this.sidePanelManager.element),this.registerDisposer(this.sidePanelManager.registerPanel({location:this.statisticsDisplayState.location,makePanel:()=>new Z_(this.sidePanelManager,this.chunkQueueManager,this.statisticsDisplayState)})),this.registerDisposer(this.sidePanelManager.registerPanel({location:this.helpPanelState.location,makePanel:()=>{const{inputEventBindings:a}=this;return new f_(this.sidePanelManager,this.helpPanelState,[["Global",a.global],["Cross section view",a.sliceView],["3-D projection view",a.perspectiveView]],this.layerManager,this.globalToolBinder)}})),this.registerDisposer(this.sidePanelManager.registerPanel({location:this.settingsPanelState.location,makePanel:()=>new nV(this.sidePanelManager,this.settingsPanelState,this)}));const o=()=>{const a=this.visibility.visible;a!==this.visible&&(e.style.visibility=a?"inherit":"hidden",this.visible=a)};o(),this.registerDisposer(this.visibility.changed.add(o))}registerEventActionBindings(){const{element:e}=this;this.registerDisposer(new yn(e,this.inputEventMap)),this.registerDisposer(new za(e))}bindAction(e,t){this.registerDisposer(Z(this.element,e,t))}registerActionListeners(){for(const t of["recolor","clear-segments"])this.bindAction(t,()=>{this.layerManager.invokeAction(t)});const e=t=>{const n=this.selectedLayer.layer?.layer;n&&n.dispatchLayerEvent(t)};this.bindAction("select-previous",()=>{e("select-previous")}),this.bindAction("select-next",()=>{e("select-next")});for(const t of["select","star"])this.bindAction(t,()=>{this.mouseState.updateUnconditionally(),this.layerManager.invokeAction(t)});this.bindAction("help",()=>this.toggleHelpPanel());for(let t=1;t<=9;++t)this.bindAction(`toggle-layer-${t}`,()=>{const n=this.layerManager.getLayerByNonArchivedIndex(t-1);n!==void 0&&n.setVisible(!n.visible)}),this.bindAction(`toggle-pick-layer-${t}`,()=>{const n=this.layerManager.getLayerByNonArchivedIndex(t-1);n!==void 0&&(n.pickEnabled=!n.pickEnabled)}),this.bindAction(`select-layer-${t}`,()=>{const n=this.layerManager.getLayerByNonArchivedIndex(t-1);n!==void 0&&(this.selectedLayer.layer=n,this.selectedLayer.visible=!0)});for(let t=0;t<26;++t){const n=String.fromCharCode(65+t);this.bindAction(`tool-${n}`,()=>{this.activateTool(n)})}this.bindAction("annotate",()=>{const t=this.selectedLayer.layer;if(t===void 0){pe.showTemporaryMessage("The annotate command requires a layer to be selected.");return}const n=t.layer;if(n===null||n.tool.value===void 0){pe.showTemporaryMessage(`The selected layer (${JSON.stringify(t.name)}) does not have an active annotation tool.`);return}n.tool.value.trigger(this.mouseState)}),this.bindAction("toggle-axis-lines",()=>this.showAxisLines.toggle()),this.bindAction("toggle-scale-bar",()=>this.showScaleBar.toggle()),this.bindAction("toggle-default-annotations",()=>this.showDefaultAnnotations.toggle()),this.bindAction("toggle-show-slices",()=>this.showPerspectiveSliceViews.toggle()),this.bindAction("toggle-show-statistics",()=>this.showStatistics())}toggleHelpPanel(){this.helpPanelState.location.visible=!this.helpPanelState.location.visible}activateTool(e,t){this.globalToolBinder.activate(e,t)}editJsonState(){new W_(this)}showStatistics(e=void 0){e===void 0&&(e=!this.statisticsDisplayState.location.visible),this.statisticsDisplayState.location.visible=e}get gl(){return this.display.gl}onUpdateDisplay(){this.visible&&(this.dataContext.chunkQueueManager.chunkUpdateDeadline=null)}handleNavigationStateChanged(){if(this.visible){const{chunkQueueManager:e}=this.dataContext;e.chunkUpdateDeadline===null&&(e.chunkUpdateDeadline=Date.now()+10)}}isReady(){if(this.chunkQueueManager.flushPendingChunkUpdates(),!this.display.isReady())return!1;for(const e of this.layerManager.managedLayers)if(!e.isReady())return!1;return!0}}$x(zb),zx(ro),Gx(Rn);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function cV(i={}){try{let{target:e=document.getElementById("neuroglancer-container")}=i;e===null&&(e=document.createElement("div"),e.id="neuroglancer-container",document.body.appendChild(e));const t=new QC(e);return new zb(t,i)}catch(e){throw pe.showMessage(`Error: ${e.message}`),e}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function dV(i){return YN(),QN(),cV(i)}/** + * @license + * Copyright 2021 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function uV(i){const e=(0,Qe.t)(()=>{const n=i.value?.trim();n?document.title=`${n} - neuroglancer`:document.title="neuroglancer"}),t=i.changed.add(e);return e(),e.flush(),()=>{t(),e.cancel()}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */function hV(i){return encodeURI(i).replace(/[!'()*;,]/g,e=>"%"+e.charCodeAt(0).toString(16).toUpperCase())}class pV extends T.O8{constructor(e,t,n={}){super(),this.root=e,this.credentialsManager=t,this.parseError=new _.B0(void 0);const{updateDelayMilliseconds:s=200,defaultFragment:r="{}"}=n;this.registerEventListener(window,"hashchange",()=>this.updateFromUrlHash());const o=(0,Fe.A)(()=>this.setUrlHash(),s,{maxWait:s*2});this.registerDisposer(e.changed.add(o)),this.registerDisposer(()=>o.cancel()),this.defaultFragment=r}setUrlHash(){const e=Lo(this.root),{generation:t}=e;if(t!==this.prevStateGeneration){this.prevStateGeneration=e.generation;const n=hV(JSON.stringify(e.value));n!==this.prevStateString&&(this.prevStateString=n,decodeURIComponent(n)==="{}"?history.replaceState(null,"","#"):history.replaceState(null,"","#!"+n))}}updateFromUrlHash(){try{let e=location.href.replace(/^[^#]+/,"");if((e===""||e==="#"||e==="#!")&&(e="#!"+this.defaultFragment),e.match(/^#!([a-z][a-z\d+-.]*):\/\//)){const t=e.substring(2),{url:n,credentialsProvider:s}=wn(t,this.credentialsManager);pe.forPromise(Nt(s,n,{},ke.cj).then(r=>{(0,f.Rf)(r),this.root.reset(),this.root.restoreState(r)}),{initialMessage:`Loading state from ${t}`,errorPrefix:"Error loading state:"})}else if(e.startsWith("#!+")){e=e.slice(3),e=decodeURIComponent(e);const t=(0,f.Sf)(e);(0,f.Rf)(t),this.root.restoreState(t),this.prevStateString=void 0}else if(e.startsWith("#!")){if(e=e.slice(2),e=decodeURIComponent(e),e===this.prevStateString)return;this.prevStateString=e,this.root.reset();const t=(0,f.Sf)(e);(0,f.Rf)(t),this.root.restoreState(t)}else throw new Error('URL hash is expected to be of the form "#!{...}" or "#!+{...}".');this.parseError.value=void 0}catch(e){this.parseError.value=e}}}/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */const fV=typeof{keym:{layer:"segmentation",tool:"grapheneMergeSegments",provider:"graphene"},keyc:{layer:"segmentation",tool:"grapheneMulticutSegments",provider:"graphene"},keyf:{layer:"segmentation",tool:"grapheneFindPath",provider:"graphene"},keyx:!1,"control+shift+keyx":"clear-segments",bracketleft:"select-previous",bracketright:"select-next"}<"u"&&Object.keys({keym:{layer:"segmentation",tool:"grapheneMergeSegments",provider:"graphene"},keyc:{layer:"segmentation",tool:"grapheneMulticutSegments",provider:"graphene"},keyf:{layer:"segmentation",tool:"grapheneFindPath",provider:"graphene"},keyx:!1,"control+shift+keyx":"clear-segments",bracketleft:"select-previous",bracketright:"select-next"}).length>0;function gV(){const i=window.viewer=dV();RD(i.inputEventBindings);const e=(n,s,r,o)=>{let a,l;typeof n=="string"&&(n={type:n}),(0,f.Rf)(n);const c=(0,f.cQ)(n,"type",f.zr);i.bindAction(`tool-${c}`,()=>{const d=i.layerManager.managedLayers.filter(u=>{const h=u.layer instanceof r;if(o&&h){for(const p of u.layer?.dataSources||[])if(i.dataSourceProvider.getProvider(p.spec.url)[2]===o)return!0;return!1}else return h});if(d.length>0){const u=d[0].layer;u&&(u!==l&&(a=Tc(u,n),l=u),a&&i.activateTool(s,a))}})};if(fV){const n=(s,r)=>{s.delete(r);for(const o of s.parents)n(o,r)};for(const[s,r]of Object.entries({keym:{layer:"segmentation",tool:"grapheneMergeSegments",provider:"graphene"},keyc:{layer:"segmentation",tool:"grapheneMulticutSegments",provider:"graphene"},keyf:{layer:"segmentation",tool:"grapheneFindPath",provider:"graphene"},keyx:!1,"control+shift+keyx":"clear-segments",bracketleft:"select-previous",bracketright:"select-next"}))if(n(i.inputEventBindings.global,s),n(i.inputEventBindings.perspectiveView,s),n(i.inputEventBindings.sliceView,s),typeof r=="string")i.inputEventBindings.global.set(s,r);else if(typeof r!="boolean"){i.inputEventBindings.global.set(s,`tool-${r.tool}`);const o=Mr.get(r.layer);if(o){const a=s.charAt(s.length-1).toUpperCase();e(r.tool,a,o,r.provider)}}}const t=i.registerDisposer(new pV(i.state,i.dataSourceProvider.credentialsManager,{defaultFragment:typeof NEUROGLANCER_DEFAULT_STATE_FRAGMENT<"u"?NEUROGLANCER_DEFAULT_STATE_FRAGMENT:void 0}));return i.registerDisposer(t.parseError.changed.add(()=>{const{value:n}=t.parseError;n!==void 0&&(new pe().setErrorMessage(`Error parsing state: ${n.message}`),console.log("Error parsing state",n)),t.parseError})),t.updateFromUrlHash(),i.registerDisposer(uV(i.title)),HN(i),jN(i),i}var P2=G(8626);/** + * @license + * Copyright 2016 Google Inc. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */gV()}},Hb={};function _e(se){var Ee=Hb[se];if(Ee!==void 0)return Ee.exports;var G=Hb[se]={exports:{}};return Wb[se].call(G.exports,G,G.exports,_e),G.exports}_e.m=Wb,_e.x=()=>{var se=_e.O(void 0,[562,993,367],()=>_e(4320));return se=_e.O(se),se},(()=>{var se=[];_e.O=(Ee,G,_,F)=>{if(G){F=F||0;for(var fe=se.length;fe>0&&se[fe-1][2]>F;fe--)se[fe]=se[fe-1];se[fe]=[G,_,F];return}for(var C=1/0,fe=0;fe=F)&&Object.keys(_e.O).every(tt=>_e.O[tt](G[Le]))?G.splice(Le--,1):(ye=!1,F{var Ee=se&&se.__esModule?()=>se.default:()=>se;return _e.d(Ee,{a:Ee}),Ee},_e.d=(se,Ee)=>{for(var G in Ee)_e.o(Ee,G)&&!_e.o(se,G)&&Object.defineProperty(se,G,{enumerable:!0,get:Ee[G]})},_e.f={},_e.e=se=>Promise.all(Object.keys(_e.f).reduce((Ee,G)=>(_e.f[G](se,Ee),Ee),[])),_e.u=se=>se===717?"neuroglancer_chunk_worker.6de531489d574d806f47.js":""+se+"."+{367:"ad6071abcab399305157",562:"1d0cecad9cc0725955f0",993:"ca23372ceee17151541a"}[se]+".js",_e.miniCssF=se=>{},_e.o=(se,Ee)=>Object.prototype.hasOwnProperty.call(se,Ee),_e.r=se=>{typeof Symbol<"u"&&Symbol.toStringTag&&Object.defineProperty(se,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(se,"__esModule",{value:!0})},(()=>{var se;if(typeof import.meta.url=="string"&&(se=import.meta.url),!se)throw new Error("Automatic publicPath is not supported in this browser");se=se.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),_e.p=se})(),(()=>{_e.b=new URL("./",import.meta.url);var se={792:0},Ee=G=>{var{ids:_,modules:F,runtime:fe}=G,C,ye,Le=0;for(C in F)_e.o(F,C)&&(_e.m[C]=F[C]);for(fe&&fe(_e);Le<_.length;Le++)ye=_[Le],_e.o(se,ye)&&se[ye]&&se[ye][0](),se[_[Le]]=0;_e.O()};_e.f.j=(G,_)=>{var F=_e.o(se,G)?se[G]:void 0;if(F!==0)if(F)_.push(F[1]);else{var fe=import("./"+_e.u(G)).then(Ee,C=>{throw se[G]!==0&&(se[G]=void 0),C}),fe=Promise.race([fe,new Promise(C=>F=se[G]=[C])]);_.push(F[1]=fe)}},_e.O.j=G=>se[G]===0})(),(()=>{var se=_e.x;_e.x=()=>Promise.all([562,993,367].map(_e.e,_e)).then(se)})();var N2=_e.x(); + +//# sourceMappingURL=main.cb26101b553ed6b82856.js.map \ No newline at end of file diff --git a/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.js.map b/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.js.map new file mode 100644 index 0000000..cfed18d --- /dev/null +++ b/neuvue_project/workspace/static/spelunker-workspace/main.cb26101b553ed6b82856.js.map @@ -0,0 +1 @@ +{"version":3,"file":"main.cb26101b553ed6b82856.js","mappings":"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ACA,CACA,OAAOwnC,GACLxsC,EACA,CAACzL,EAAI+N,EAAUluC,EAAQyf,IAAW,CAChC0gB,EAAG,oBACD+N,EACUyH,EACAhF,EACMC,EAChB5wC,EACAyf,CACF,CACF,CACF,CACF,CAEA,SAASg5D,GACP7sC,EACA+J,EACAhF,EACA,CACA,OAAOynC,GACLxsC,EACA,CAACzL,EAAI+N,EAAUluC,EAAQyf,IAAW,CAChC0gB,EAAG,qBACD+N,EACUyH,EACAhF,EACV3wC,EACAyf,CACF,CACF,CACF,CACF,CAEA,MAAMi5D,GAEF,CACF,IAAKF,GACH,aACA,EACA,uBAAuB,cACP,EAClB,EACA,KAAMA,GACJ,aACA,EACA,uBAAuB,cACP,EAClB,EACA,QAASA,GACP,cACA,EACA,uBAAuB,MACP,EAClB,EACA,OAAQC,GACN,aACA,EACA,uBAAuB,YACzB,EACA,MAAOA,GACL,YACA,EACA,uBAAuB,GACzB,EACA,OAAQA,GACN,aACA,EACA,uBAAuB,cACzB,EACA,MAAOA,GACL,YACA,EACA,uBAAuB,KACzB,EACA,MAAOA,GACL,aACA,EACA,uBAAuB,aACzB,EACA,KAAMA,GACJ,YACA,EACA,uBAAuB,IACzB,CACF,EAEA,MAAME,WAAmC,IAAW,CAQlD,YACSx4C,EACA5e,EACArY,EACAgZ,EACP,CACA,MAAM,EALC,QAAAie,EACA,oBAAA5e,EACA,UAAArY,EACA,gBAAAgZ,EAGP,MAAM02D,EACH,KAAK,qCACJp3D,GAAuBD,CAAc,EAAE,gBAAgBrY,CAAI,EACzD,CACJ,QAAAkX,EACA,gBAAiBy4D,EACjB,mBAAA54D,CACF,EAAIN,GACFzW,EACA0vE,EACA12D,CACF,EACA,KAAK,6BAA+B22D,EACpC,KAAK,gBAAkBz4D,EACvB,KAAK,mBAAqBH,EAC1B,KAAK,mBAAqBA,EAAmB,CAAC,EAC9C,MAAM64D,EAAgC,KAAK,6BACzC,IAAI,MAAc74D,EAAmB,MAAM,EAC7C64D,EAA6B,CAAC,EAAI,EAClC,QAAS56E,EAAI,EAAGA,EAAI+hB,EAAmB,OAAQ,EAAE/hB,EAC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AAqBC,EAAmB,CAE/C,IAAIC,EAAmB,EACvB,QAASC,EAAS,EAAGA,EAAS,EAAG,EAAEA,EAG7BF,EAAYE,CAAM,EAAI,IACxBD,GAAoB,GAAKC,GAG7B,OAAOD,CACT,CAGO,MAAME,GAAsB,IAAI,aAAa,CAClD,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,CACF,CAAC,EAEYC,IAAwC,IAAM,CAwBzD,MAAMC,EAA+B,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,CAAC,EAGtDC,EAA+B,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,CAAC,EAGtDC,EAAoB,CACxB,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,CACF,EAIMC,EAAoB,CACxB,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,CACF,EAEMC,EAAgB,IAAI,WAAW,EAAI,EAAI,CAAC,EAC9C,QAAS7/G,EAAI,EAAGA,EAAI,EAAG,EAAEA,EACvB,QAAS/K,EAAI,EAAGA,EAAI0qH,EAAkB,OAAQ,EAAE1qH,EAAG,CACjD,MAAM6qH,EACJJ,EAA6B1/G,CAAC,EAAI,EAAI2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","sources":["webpack://neuroglancer/./src/segmentation_graph/segment_id.ts","webpack://neuroglancer/./src/trackable_value.ts","webpack://neuroglancer/./src/util/array.ts","webpack://neuroglancer/./src/util/cancellation.ts","webpack://neuroglancer/./src/util/disposable.ts","webpack://neuroglancer/./src/util/geom.ts","webpack://neuroglancer/./src/util/google_tag_manager.ts","webpack://neuroglancer/./src/util/http_request.ts","webpack://neuroglancer/./src/util/json.ts","webpack://neuroglancer/./src/util/matrix.ts","webpack://neuroglancer/./src/util/signal.ts","webpack://neuroglancer/./src/util/hex.ts","webpack://neuroglancer/./src/util/color.ts","webpack://neuroglancer/./src/util/data_type.ts","webpack://neuroglancer/./src/util/endian.ts","webpack://neuroglancer/./src/util/float.ts","webpack://neuroglancer/./src/util/lerp.ts","webpack://neuroglancer/./src/util/random.ts","webpack://neuroglancer/./src/annotation/index.ts","webpack://neuroglancer/./src/util/si_units.ts","webpack://neuroglancer/./src/util/vector.ts","webpack://neuroglancer/./src/coordinate_transform.ts","webpack://neuroglancer/./src/render_coordinate_transform.ts","webpack://neuroglancer/./src/chunk_manager/base.ts","webpack://neuroglancer/./src/util/framerate.ts","webpack://neuroglancer/./src/display_context.ts","webpack://neuroglancer/./src/projection_parameters.ts","webpack://neuroglancer/./src/util/message_list.ts","webpack://neuroglancer/./src/worker_rpc.ts","webpack://neuroglancer/./src/shared_watchable_value.ts","webpack://neuroglancer/./src/visibility_priority/frontend.ts","webpack://neuroglancer/./src/renderlayer.ts","webpack://neuroglancer/./src/trackable_boolean.ts","webpack://neuroglancer/./src/util/error.ts","webpack://neuroglancer/./src/util/watchable_map.ts","webpack://neuroglancer/./src/util/object_id.ts","webpack://neuroglancer/./src/webgl/shader.ts","webpack://neuroglancer/./src/webgl/dynamic_shader.ts","webpack://neuroglancer/./src/webgl/buffer.ts","webpack://neuroglancer/./src/webgl/square_corners_buffer.ts","webpack://neuroglancer/./src/webgl/texture.ts","webpack://neuroglancer/./src/webgl/trivial_shaders.ts","webpack://neuroglancer/./src/webgl/offscreen.ts","webpack://neuroglancer/./src/webgl/shader_lib.ts","webpack://neuroglancer/./src/webgl/empirical_cdf.ts","webpack://neuroglancer/./src/webgl/lerp.ts","webpack://neuroglancer/./src/util/trackable.ts","webpack://neuroglancer/./src/navigation_state.ts","webpack://neuroglancer/./src/util/hierarchical_map.ts","webpack://neuroglancer/./src/util/event_action_map.ts","webpack://neuroglancer/./src/util/mouse_bindings.ts","webpack://neuroglancer/./src/util/mouse_drag.ts","webpack://neuroglancer/./src/util/wheel_zoom.ts","webpack://neuroglancer/./src/webgl/quad.ts","webpack://neuroglancer/./src/webgl/lines.ts","webpack://neuroglancer/./src/webgl/rectangle_grid_buffer.ts","webpack://neuroglancer/./src/util/colorspace.ts","webpack://neuroglancer/./src/widget/color.ts","webpack://neuroglancer/./src/util/dom.ts","webpack://neuroglancer/./src/widget/icon.ts","webpack://neuroglancer/./src/widget/tab_view.ts","webpack://neuroglancer/./src/widget/invlerp.ts","webpack://neuroglancer/./src/widget/close_button.ts","webpack://neuroglancer/./src/status.ts","webpack://neuroglancer/./src/ui/tool.ts","webpack://neuroglancer/./src/util/clipboard.ts","webpack://neuroglancer/./src/util/keyboard_bindings.ts","webpack://neuroglancer/./src/widget/checkbox_icon.ts","webpack://neuroglancer/./src/widget/copy_button.ts","webpack://neuroglancer/./src/widget/dependent_view_widget.ts","webpack://neuroglancer/./src/widget/enum_widget.ts","webpack://neuroglancer/./src/widget/number_input_widget.ts","webpack://neuroglancer/./src/widget/position_plot.ts","webpack://neuroglancer/./src/widget/position_widget.ts","webpack://neuroglancer/./src/widget/transfer_function.ts","webpack://neuroglancer/./src/webgl/shader_ui_controls.ts","webpack://neuroglancer/./src/annotation/annotation_layer_state.ts","webpack://neuroglancer/./src/sliceview/base.ts","webpack://neuroglancer/./src/annotation/base.ts","webpack://neuroglancer/./src/webgl/colormaps.ts","webpack://neuroglancer/./src/annotation/type_handler.ts","webpack://neuroglancer/./src/chunk_manager/frontend.ts","webpack://neuroglancer/./src/segmentation_display_state/base.ts","webpack://neuroglancer/./src/render_scale_statistics.ts","webpack://neuroglancer/./src/sliceview/renderlayer.ts","webpack://neuroglancer/./src/sliceview/frontend.ts","webpack://neuroglancer/./src/annotation/frontend_source.ts","webpack://neuroglancer/./src/util/completion.ts","webpack://neuroglancer/./src/datasource/index.ts","webpack://neuroglancer/./src/layer/layer_data_source.ts","webpack://neuroglancer/./src/ui/side_panel_location.ts","webpack://neuroglancer/./src/ui/layer_side_panel_state.ts","webpack://neuroglancer/./src/util/signal_binding_updater.ts","webpack://neuroglancer/./src/layer/index.ts","webpack://neuroglancer/./src/layer/segmentation/json_keys.ts","webpack://neuroglancer/./src/widget/layer_control.ts","webpack://neuroglancer/./src/widget/layer_control_checkbox.ts","webpack://neuroglancer/./src/widget/layer_control_enum.ts","webpack://neuroglancer/./src/widget/range.ts","webpack://neuroglancer/./src/widget/layer_control_range.ts","webpack://neuroglancer/./src/util/number_to_string.ts","webpack://neuroglancer/./src/widget/render_scale_widget.ts","webpack://neuroglancer/./src/widget/layer_control_color.ts","webpack://neuroglancer/./src/widget/text_input.ts","webpack://neuroglancer/./src/widget/segmentation_color_mode.ts","webpack://neuroglancer/./src/layer/segmentation/layer_controls.ts","webpack://neuroglancer/./src/util/zorder.ts","webpack://neuroglancer/./src/mesh/multiscale.ts","webpack://neuroglancer/./src/perspective_view/render_layer.ts","webpack://neuroglancer/./src/gpu_hash/hash_table.ts","webpack://neuroglancer/./src/webgl/texture_access.ts","webpack://neuroglancer/./src/gpu_hash/shader.ts","webpack://neuroglancer/./src/segment_color.ts","webpack://neuroglancer/./src/ui/default_input_event_bindings.ts","webpack://neuroglancer/./src/ui/drag_and_drop.ts","webpack://neuroglancer/./src/ui/side_panel.ts","webpack://neuroglancer/./src/widget/move_to_button.ts","webpack://neuroglancer/./src/ui/selection_details.ts","webpack://neuroglancer/./src/widget/eye_button.ts","webpack://neuroglancer/./src/widget/filter_button.ts","webpack://neuroglancer/./src/widget/star_button.ts","webpack://neuroglancer/./src/segmentation_display_state/frontend.ts","webpack://neuroglancer/./src/mesh/frontend.ts","webpack://neuroglancer/./src/util/hash.ts","webpack://neuroglancer/./src/segmentation_display_state/property_map.ts","webpack://neuroglancer/./src/segmentation_graph/source.ts","webpack://neuroglancer/./src/shared_disjoint_sets.ts","webpack://neuroglancer/./src/segmentation_graph/local.ts","webpack://neuroglancer/./src/webgl/circles.ts","webpack://neuroglancer/./src/webgl/vertex_id.ts","webpack://neuroglancer/./src/skeleton/frontend.ts","webpack://neuroglancer/./src/sliceview/volume/base.ts","webpack://neuroglancer/./src/sliceview/volume/frontend.ts","webpack://neuroglancer/./src/sliceview/bounding_box_shader_helper.ts","webpack://neuroglancer/./src/sliceview/volume/renderlayer.ts","webpack://neuroglancer/./src/sliceview/volume/segmentation_renderlayer.ts","webpack://neuroglancer/./src/trackable_alpha.ts","webpack://neuroglancer/./src/webgl/bounding_box.ts","webpack://neuroglancer/./src/annotation/bounding_box.ts","webpack://neuroglancer/./src/annotation/line.ts","webpack://neuroglancer/./src/annotation/point.ts","webpack://neuroglancer/./src/webgl/ellipse.ts","webpack://neuroglancer/./src/webgl/spheres.ts","webpack://neuroglancer/./src/annotation/ellipsoid.ts","webpack://neuroglancer/./src/sliceview/wire_frame.ts","webpack://neuroglancer/./src/annotation/renderlayer.ts","webpack://neuroglancer/./src/widget/add_button.ts","webpack://neuroglancer/./src/widget/delete_button.ts","webpack://neuroglancer/./src/widget/virtual_list.ts","webpack://neuroglancer/./src/ui/annotations.ts","webpack://neuroglancer/./src/ui/segment_select_tools.ts","webpack://neuroglancer/./src/ui/segment_split_merge_tools.ts","webpack://neuroglancer/./src/ui/segment_list.ts","webpack://neuroglancer/./src/util/automatic_focus.ts","webpack://neuroglancer/./src/overlay.ts","webpack://neuroglancer/./src/widget/help_button.ts","webpack://neuroglancer/./src/widget/linked_layer.ts","webpack://neuroglancer/./src/widget/maximize_button.ts","webpack://neuroglancer/./src/widget/shader_code_widget.ts","webpack://neuroglancer/./src/widget/layer_control_channel_invlerp.ts","webpack://neuroglancer/./src/widget/layer_control_property_invlerp.ts","webpack://neuroglancer/./src/widget/shader_controls.ts","webpack://neuroglancer/./src/ui/segmentation_display_options_tab.ts","webpack://neuroglancer/./src/uint64_map.ts","webpack://neuroglancer/./src/uint64_ordered_set.ts","webpack://neuroglancer/./src/uint64_set.ts","webpack://neuroglancer/./src/layer/segmentation/index.ts","webpack://neuroglancer/./src/widget/coordinate_transform.ts","webpack://neuroglancer/./src/util/dropdown.ts","webpack://neuroglancer/./src/util/longest_common_prefix.ts","webpack://neuroglancer/./src/widget/multiline_autocomplete.ts","webpack://neuroglancer/./src/ui/layer_data_sources_tab.ts","webpack://neuroglancer/./src/widget/layer_reference.ts","webpack://neuroglancer/./src/layer/annotation/index.ts","webpack://neuroglancer/./src/trackable_blend.ts","webpack://neuroglancer/./src/sliceview/volume/image_renderlayer.ts","webpack://neuroglancer/./src/trackable_finite_float.ts","webpack://neuroglancer/./src/volume_rendering/trackable_volume_rendering_mode.ts","webpack://neuroglancer/./src/volume_rendering/base.ts","webpack://neuroglancer/./src/volume_rendering/volume_render_layer.ts","webpack://neuroglancer/./src/widget/channel_dimensions_widget.ts","webpack://neuroglancer/./src/layer/image/index.ts","webpack://neuroglancer/./src/credentials_provider/shared.ts","webpack://neuroglancer/./src/credentials_provider/chunk_source_frontend.ts","webpack://neuroglancer/./src/util/false.ts","webpack://neuroglancer/./src/util/s3_bucket_listing.ts","webpack://neuroglancer/./src/util/s3.ts","webpack://neuroglancer/./src/util/special_protocol_request.ts","webpack://neuroglancer/./src/webgl/index_emulation.ts","webpack://neuroglancer/./src/single_mesh/frontend.ts","webpack://neuroglancer/./src/layer/single_mesh/index.ts","webpack://neuroglancer/./src/datasource/boss/api.ts","webpack://neuroglancer/./src/datasource/boss/frontend.ts","webpack://neuroglancer/./src/datasource/default_provider.ts","webpack://neuroglancer/./src/datasource/boss/register_default.ts","webpack://neuroglancer/./src/credentials_provider/index.ts","webpack://neuroglancer/./src/credentials_provider/default_manager.ts","webpack://neuroglancer/./src/datasource/boss/credentials_provider.ts","webpack://neuroglancer/./src/datasource/boss/register_credentials_provider.ts","webpack://neuroglancer/./src/datasource/brainmaps/api.ts","webpack://neuroglancer/./src/datasource/brainmaps/frontend.ts","webpack://neuroglancer/./src/datasource/brainmaps/register_default.ts","webpack://neuroglancer/./src/util/google_oauth2.ts","webpack://neuroglancer/./src/datasource/brainmaps/credentials_provider.ts","webpack://neuroglancer/./src/datasource/brainmaps/register_credentials_provider.ts","webpack://neuroglancer/./src/datasource/dvid/api.ts","webpack://neuroglancer/./src/util/gcs_bucket_listing.ts","webpack://neuroglancer/./src/util/http_path_completion.ts","webpack://neuroglancer/./src/datasource/precomputed/frontend.ts","webpack://neuroglancer/./src/datasource/deepzoom/frontend.ts","webpack://neuroglancer/./src/datasource/deepzoom/register_default.ts","webpack://neuroglancer/./src/datasource/dvid/frontend.ts","webpack://neuroglancer/./src/datasource/dvid/register_default.ts","webpack://neuroglancer/./src/datasource/dvid/credentials_provider.ts","webpack://neuroglancer/./src/datasource/dvid/register_credentials_provider.ts","webpack://neuroglancer/./src/datasource/graphene/base.ts","webpack://neuroglancer/./src/widget/datetime.ts","webpack://neuroglancer/./src/datasource/graphene/frontend.ts","webpack://neuroglancer/./src/datasource/graphene/register_default.ts","webpack://neuroglancer/./src/datasource/middleauth/credentials_provider.ts","webpack://neuroglancer/./src/datasource/middleauth/register_credentials_provider.ts","webpack://neuroglancer/./src/datasource/n5/frontend.ts","webpack://neuroglancer/./src/datasource/n5/register_default.ts","webpack://neuroglancer/./src/datasource/ngauth/credentials_provider.ts","webpack://neuroglancer/./src/datasource/ngauth/register_credentials_provider.ts","webpack://neuroglancer/./src/datasource/nggraph/credentials_provider.ts","webpack://neuroglancer/./src/datasource/nggraph/frontend.ts","webpack://neuroglancer/./src/datasource/nggraph/register_default.ts","webpack://neuroglancer/./src/datasource/nifti/frontend.ts","webpack://neuroglancer/./src/datasource/nifti/register_default.ts","webpack://neuroglancer/./src/datasource/obj/frontend.ts","webpack://neuroglancer/./src/datasource/obj/register_default.ts","webpack://neuroglancer/./src/datasource/precomputed/register_default.ts","webpack://neuroglancer/./src/datasource/render/frontend.ts","webpack://neuroglancer/./src/datasource/render/register_default.ts","webpack://neuroglancer/./src/datasource/vtk/frontend.ts","webpack://neuroglancer/./src/datasource/vtk/register_default.ts","webpack://neuroglancer/./src/datasource/zarr/metadata/parse_util.ts","webpack://neuroglancer/./src/datasource/zarr/codec/resolve.ts","webpack://neuroglancer/./src/datasource/zarr/codec/blosc/resolve.ts","webpack://neuroglancer/./src/datasource/zarr/codec/zstd/resolve.ts","webpack://neuroglancer/./src/datasource/zarr/codec/bytes/resolve.ts","webpack://neuroglancer/./src/datasource/zarr/codec/crc32c/resolve.ts","webpack://neuroglancer/./src/datasource/zarr/codec/gzip/resolve.ts","webpack://neuroglancer/./src/datasource/zarr/metadata/index.ts","webpack://neuroglancer/./src/util/numpy_dtype.ts","webpack://neuroglancer/./src/datasource/zarr/metadata/parse.ts","webpack://neuroglancer/./src/datasource/zarr/codec/sharding_indexed/resolve.ts","webpack://neuroglancer/./src/datasource/zarr/codec/transpose/resolve.ts","webpack://neuroglancer/./src/datasource/zarr/ome.ts","webpack://neuroglancer/./src/datasource/zarr/frontend.ts","webpack://neuroglancer/./src/datasource/zarr/register_default.ts","webpack://neuroglancer/./src/ui/default_clipboard_handling.ts","webpack://neuroglancer/./src/ui/disable_default_actions.ts","webpack://neuroglancer/./src/sliceview/single_texture_chunk_format.ts","webpack://neuroglancer/./src/sliceview/uncompressed_chunk_format.ts","webpack://neuroglancer/./src/sliceview/compressed_segmentation/decode_common.ts","webpack://neuroglancer/./src/sliceview/compressed_segmentation/decode_uint32.ts","webpack://neuroglancer/./src/sliceview/compressed_segmentation/decode_uint64.ts","webpack://neuroglancer/./src/sliceview/compressed_segmentation/chunk_format.ts","webpack://neuroglancer/./src/sliceview/chunk_format_handlers.ts","webpack://neuroglancer/./src/layout.ts","webpack://neuroglancer/./src/axes_lines.ts","webpack://neuroglancer/./src/object_picking.ts","webpack://neuroglancer/./src/util/touch_bindings.ts","webpack://neuroglancer/./src/rendered_data_panel.ts","webpack://neuroglancer/./src/widget/scale_bar.ts","webpack://neuroglancer/./src/perspective_view/panel.ts","webpack://neuroglancer/./src/sliceview/panel.ts","webpack://neuroglancer/./src/widget/display_dimensions_widget.ts","webpack://neuroglancer/./src/data_panel_layout.ts","webpack://neuroglancer/./src/datasource/state_share.ts","webpack://neuroglancer/./src/help/input_event_bindings.ts","webpack://neuroglancer/./src/ui/context_menu.ts","webpack://neuroglancer/./src/util/drag_and_drop.ts","webpack://neuroglancer/./src/ui/layer_drag_and_drop.ts","webpack://neuroglancer/./src/ui/layer_bar.ts","webpack://neuroglancer/./src/ui/position_drag_and_drop.ts","webpack://neuroglancer/./src/layer_group_viewer.ts","webpack://neuroglancer/./src/layer_groups_layout.ts","webpack://neuroglancer/./src/ui/layer_side_panel.ts","webpack://neuroglancer/./src/ui/layer_list_panel.ts","webpack://neuroglancer/./src/ui/state_editor.ts","webpack://neuroglancer/./src/ui/statistics.ts","webpack://neuroglancer/./src/ui/viewer_settings.ts","webpack://neuroglancer/./src/widget/annotation_tool_status.ts","webpack://neuroglancer/./src/viewer.ts","webpack://neuroglancer/./src/ui/minimal_viewer.ts","webpack://neuroglancer/./src/ui/default_viewer.ts","webpack://neuroglancer/./src/ui/title.ts","webpack://neuroglancer/./src/ui/url_hash_binding.ts","webpack://neuroglancer/./src/ui/default_viewer_setup.ts","webpack://neuroglancer/./src/main.ts","webpack://neuroglancer/webpack/bootstrap","webpack://neuroglancer/webpack/runtime/chunk loaded","webpack://neuroglancer/webpack/runtime/compat get default export","webpack://neuroglancer/webpack/runtime/define property getters","webpack://neuroglancer/webpack/runtime/ensure chunk","webpack://neuroglancer/webpack/runtime/get javascript chunk filename","webpack://neuroglancer/webpack/runtime/get mini-css chunk filename","webpack://neuroglancer/webpack/runtime/hasOwnProperty shorthand","webpack://neuroglancer/webpack/runtime/make namespace object","webpack://neuroglancer/webpack/runtime/publicPath","webpack://neuroglancer/webpack/runtime/import chunk loading","webpack://neuroglancer/webpack/runtime/startup chunk dependencies","webpack://neuroglancer/webpack/startup"],"sourcesContent":["/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Uint64 } from \"#src/util/uint64.js\";\n\nexport enum VisibleSegmentEquivalencePolicy {\n MIN_REPRESENTATIVE = 0, // defafult, representative elmement is the minimum element in equivalence set\n MAX_REPRESENTATIVE = 1, // representative elmement is the maximum element in equivalence set\n REPRESENTATIVE_EXCLUDED = 1 << 1, // filter out the representative element when iterating over visible segments\n NONREPRESENTATIVE_EXCLUDED = 1 << 2, // filter out non representative elements when iterating over visible segments\n}\n\n// Returns `true` if `segmentId` is a base segment id, rather than a segment id added to the graph.\nexport function isBaseSegmentId(segmentId: Uint64) {\n return segmentId.high >>> 31 ? false : true;\n}\n\nexport const UNKNOWN_NEW_SEGMENT_ID = new Uint64(0xffffffff, 0xffffffff);\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { debounce } from \"lodash-es\";\nimport type { Borrowed, Disposable, Owned } from \"#src/util/disposable.js\";\nimport { invokeDisposers, RefCounted } from \"#src/util/disposable.js\";\nimport type { NullaryReadonlySignal } from \"#src/util/signal.js\";\nimport { neverSignal, NullarySignal, Signal } from \"#src/util/signal.js\";\nimport type { Trackable } from \"#src/util/trackable.js\";\n\nexport interface WatchableValueInterface {\n value: T;\n changed: NullaryReadonlySignal;\n}\n\nexport interface WatchableValueChangeInterface {\n readonly value: T;\n readonly changed: Signal<(oldValue: T, newValue: T) => void>;\n}\n\nexport class WatchableValue implements WatchableValueInterface {\n get value() {\n return this.value_;\n }\n set value(newValue: T) {\n if (newValue !== this.value_) {\n this.value_ = newValue;\n this.changed.dispatch();\n }\n }\n changed = new NullarySignal();\n constructor(protected value_: T) {}\n}\n\nexport class TrackableValue extends WatchableValue implements Trackable {\n constructor(\n value: T,\n public validator: (value: any) => T,\n public defaultValue = value,\n ) {\n super(value);\n }\n toJSON(): any {\n const { value_ } = this;\n if (value_ === this.defaultValue) {\n return undefined;\n }\n return this.value_;\n }\n reset() {\n this.value = this.defaultValue;\n }\n restoreState(x: any) {\n if (x !== undefined) {\n const { validator } = this;\n try {\n this.value = validator(x);\n return;\n } catch {\n // Ignore invalid values in JSON representation.\n }\n }\n this.value = this.defaultValue;\n }\n}\n\nclass DerivedWatchableValue\n extends RefCounted\n implements WatchableValueInterface\n{\n changed = new NullarySignal();\n get value() {\n return this.f(...this.ws.map((w) => w.value));\n }\n private f: (...v: any[]) => U;\n private ws: WatchableValueInterface[];\n\n constructor(f: (...v: any[]) => U, ws: WatchableValueInterface[]) {\n super();\n this.f = f;\n this.ws = ws;\n for (const w of ws) {\n this.registerDisposer(w.changed.add(this.changed.dispatch));\n }\n }\n}\n\nexport function makeDerivedWatchableValue(\n f: (...v: T) => U,\n ...ws: { [K in keyof T]: WatchableValueInterface }\n) {\n return new DerivedWatchableValue(f, ws);\n}\n\nclass CachedLazyDerivedWatchableValue\n extends RefCounted\n implements WatchableValueInterface\n{\n changed = new NullarySignal();\n private value_: U | undefined;\n private valueGeneration = -1;\n get value() {\n const generation = this.changed.count;\n if (generation !== this.valueGeneration) {\n this.value_ = this.f(...this.ws.map((w) => w.value));\n this.valueGeneration = generation;\n }\n return this.value_ as U;\n }\n private f: (...v: any[]) => U;\n private ws: WatchableValueInterface[];\n\n constructor(f: (...v: any[]) => U, ws: WatchableValueInterface[]) {\n super();\n this.f = f;\n this.ws = ws;\n for (const w of ws) {\n this.registerDisposer(w.changed.add(this.changed.dispatch));\n }\n }\n}\n\nexport function makeCachedLazyDerivedWatchableValue(\n f: (...v: T) => U,\n ...ws: { [K in keyof T]: WatchableValueInterface }\n) {\n return new CachedLazyDerivedWatchableValue(f, ws);\n}\n\nexport class CachedWatchableValue\n extends RefCounted\n implements WatchableValueInterface\n{\n changed = new Signal();\n value: T;\n constructor(\n base: WatchableValueInterface,\n isEqual: (a: T, b: T) => boolean = (a, b) => a === b,\n ) {\n super();\n this.value = base.value;\n this.registerDisposer(\n base.changed.add(() => {\n const newValue = base.value;\n if (!isEqual(this.value, newValue)) {\n this.value = newValue;\n this.changed.dispatch();\n }\n }),\n );\n }\n}\n\nexport function makeCachedDerivedWatchableValue(\n f: (...v: T) => U,\n ws: { [K in keyof T]: WatchableValueInterface },\n isEqual?: (a: U, b: U) => boolean,\n) {\n const derived = new DerivedWatchableValue(f, ws);\n const cached = new CachedWatchableValue(derived, isEqual);\n cached.registerDisposer(derived);\n return cached;\n}\n\nexport class AggregateWatchableValue\n extends RefCounted\n implements WatchableValueInterface\n{\n changed = new NullarySignal();\n value: T;\n constructor(\n getWatchables: (self: RefCounted) => {\n [k in keyof T]: WatchableValueInterface;\n },\n ) {\n super();\n const watchables = getWatchables(this);\n const keys = Object.keys(watchables) as (keyof T)[];\n const updateValue = () => {\n const obj = (Array.isArray(watchables) ? [] : {}) as T;\n for (const k of keys) {\n obj[k] = watchables[k].value;\n }\n this.value = obj;\n this.changed.dispatch();\n };\n updateValue();\n for (const k of keys) {\n const watchable = watchables[k];\n // Ensure a unique function is used each time in case the same watchable is assigned to\n // multiple properties.\n this.registerDisposer(watchable.changed.add(() => updateValue()));\n }\n }\n}\n\nexport class ComputedWatchableValue\n extends RefCounted\n implements WatchableValueInterface\n{\n get value() {\n return this.f();\n }\n changed = new NullarySignal();\n constructor(\n public f: () => U,\n ...signals: NullarySignal[]\n ) {\n super();\n for (const signal of signals) {\n this.registerDisposer(signal.add(this.changed.dispatch));\n }\n }\n}\n\nexport class WatchableRefCounted\n extends RefCounted\n implements WatchableValueInterface\n{\n changed = new NullarySignal();\n\n private value_: Owned | undefined;\n private valueHandler: (() => void) | undefined;\n\n get value(): Borrowed | undefined {\n return this.value_;\n }\n\n set value(value: Owned | undefined) {\n const { value_ } = this;\n this.value_ = value;\n if (value_ !== undefined) {\n value_.dispose();\n value_.unregisterDisposer(this.valueHandler!);\n this.valueHandler = undefined;\n }\n if (value !== undefined) {\n const valueHandler = (this.valueHandler = () => {\n if (this.value_ === value) {\n this.value_ = undefined;\n this.changed.dispatch();\n }\n });\n value.registerDisposer(valueHandler);\n }\n\n if (value !== value_) {\n this.changed.dispatch();\n }\n }\n\n reset() {\n this.value = undefined;\n }\n\n disposed() {\n if (this.value_ !== undefined) {\n this.value_.unregisterDisposer(this.valueHandler!);\n this.value_.dispose();\n }\n this.value_ = undefined;\n super.disposed();\n }\n}\n\nexport interface TrackableValueInterface\n extends WatchableValueInterface,\n Trackable {}\n\nexport class TrackableRefCounted\n extends WatchableRefCounted\n implements TrackableValueInterface\n{\n constructor(\n public validator: (value: any) => T | undefined,\n public jsonConverter: (value: T) => any,\n ) {\n super();\n }\n toJSON() {\n const { value } = this;\n return value && this.jsonConverter(value);\n }\n\n restoreState(x: any) {\n this.value = this.validator(x);\n }\n}\n\nexport class WatchableSet {\n changed = new Signal<(x: T | null, add: boolean) => void>();\n values: Set;\n constructor(values?: Iterable) {\n if (values === undefined) {\n this.values = new Set();\n } else {\n this.values = new Set(values);\n }\n }\n add(x: T) {\n const { values } = this;\n if (!values.has(x)) {\n values.add(x);\n this.changed.dispatch(x, true);\n }\n return this;\n }\n delete(x: T) {\n const { values } = this;\n if (values.delete(x)) {\n this.changed.dispatch(x, false);\n return true;\n }\n return false;\n }\n has(x: T) {\n return this.values.has(x);\n }\n get size() {\n return this.values.size;\n }\n [Symbol.iterator]() {\n return this.values[Symbol.iterator]();\n }\n clear() {\n const { values } = this;\n if (values.size > 0) {\n values.clear();\n this.changed.dispatch(null, false);\n }\n }\n}\n\nexport interface NestedStateManager extends Disposable {\n flush: () => void;\n value: T;\n}\n\nexport function registerNested(\n f: (context: RefCounted, ...values: T) => U,\n ...watchables: { [K in keyof T]: WatchableValueInterface }\n): NestedStateManager {\n const values = watchables.map((w) => w.value) as T;\n const count = watchables.length;\n let context = new RefCounted();\n let result = f(context, ...values);\n\n const handleChange = debounce(() => {\n let changed = false;\n for (let i = 0; i < count; ++i) {\n const watchable = watchables[i];\n const value = watchable.value;\n if (values[i] !== value) {\n values[i] = value;\n changed = true;\n }\n }\n if (!changed) return;\n context.dispose();\n context = new RefCounted();\n result = f(context, ...values);\n }, 0);\n\n const signalDisposers = watchables.map((w) => w.changed.add(handleChange));\n\n return {\n flush() {\n handleChange.flush();\n },\n dispose() {\n handleChange.cancel();\n invokeDisposers(signalDisposers);\n context.dispose();\n },\n get value() {\n handleChange.flush();\n return result;\n },\n };\n}\n\nexport function registerNestedSync(\n f: (context: RefCounted, ...values: T) => U,\n ...watchables: { [K in keyof T]: WatchableValueInterface }\n): { readonly value: U; dispose(): void } {\n const values = watchables.map((w) => w.value) as T;\n const count = watchables.length;\n let context = new RefCounted();\n let result = f(context, ...values);\n\n const handleChange = () => {\n let changed = false;\n for (let i = 0; i < count; ++i) {\n const watchable = watchables[i];\n const value = watchable.value;\n if (values[i] !== value) {\n values[i] = value;\n changed = true;\n }\n }\n if (!changed) return;\n context.dispose();\n context = new RefCounted();\n result = f(context, ...values);\n };\n\n const signalDisposers = watchables.map((w) => w.changed.add(handleChange));\n\n return {\n dispose() {\n invokeDisposers(signalDisposers);\n context.dispose();\n },\n get value() {\n return result;\n },\n };\n}\n\nexport function constantWatchableValue(\n value: T,\n): WatchableValueInterface {\n return { changed: neverSignal, value };\n}\n\nexport function observeWatchable(\n callback: (value: T) => void,\n watchable: WatchableValueInterface,\n) {\n callback(watchable.value);\n return watchable.changed.add(() => callback(watchable.value));\n}\n\nexport function linkWatchableValue(\n source: WatchableValueInterface,\n target: WatchableValueInterface,\n) {\n target.value = source.value;\n return source.changed.add(() => {\n target.value = source.value;\n });\n}\n\nexport class IndirectWatchableValue\n implements Disposable, WatchableValueInterface\n{\n protected inner: WatchableValueInterface;\n changed = new NullarySignal();\n disposer: (() => void) | undefined;\n private update = () => {\n const { disposer, outer } = this;\n if (disposer !== undefined) {\n disposer();\n }\n const inner = (this.inner = this.getInner(outer.value));\n this.disposer = inner.changed.add(this.changed.dispatch);\n this.changed.dispatch();\n };\n constructor(\n private outer: WatchableValueInterface,\n private getInner: (outer: U) => WatchableValueInterface,\n ) {\n outer.changed.add(this.update);\n this.update();\n }\n\n dispose() {\n this.outer.changed.remove(this.update);\n this.disposer!();\n }\n\n get value() {\n return this.inner.value;\n }\n set value(value: T) {\n this.inner.value = value;\n }\n}\n\nexport class IndirectTrackableValue\n extends IndirectWatchableValue\n implements Trackable\n{\n declare inner: TrackableValueInterface;\n reset() {\n this.inner.reset();\n }\n restoreState(obj: unknown) {\n this.inner.restoreState(obj);\n }\n toJSON() {\n return this.inner.toJSON();\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport interface WritableArrayLike {\n length: number;\n [n: number]: T;\n}\n\n/**\n * Partitions array[start:end] such that all elements for which predicate\n * returns true are before the elements for which predicate returns false.\n *\n * predicate will be called exactly once for each element in array[start:end],\n * in order.\n *\n * @returns {number} The index of the first element for which predicate returns\n * false, or end if there is no such element.\n */\nexport function partitionArray(\n array: T[],\n start: number,\n end: number,\n predicate: (x: T) => boolean,\n): number {\n while (start < end) {\n const x = array[start];\n if (predicate(x)) {\n ++start;\n continue;\n }\n --end;\n array[start] = array[end];\n array[end] = x;\n }\n return end;\n}\n\nexport function filterArrayInplace(\n array: T[],\n predicate: (x: T, index: number, array: T[]) => boolean,\n) {\n const length = array.length;\n let outIndex = 0;\n for (let i = 0; i < length; ++i) {\n if (predicate(array[i], i, array)) {\n array[outIndex] = array[i];\n ++outIndex;\n }\n }\n array.length = outIndex;\n}\n\nexport type TypedArrayConstructor =\n | typeof Int8Array\n | typeof Uint8Array\n | typeof Int16Array\n | typeof Uint16Array\n | typeof Int32Array\n | typeof Uint32Array\n | typeof Float32Array\n | typeof Float64Array;\n\nexport type TypedArray =\n | Int8Array\n | Uint8Array\n | Int16Array\n | Uint16Array\n | Int32Array\n | Uint32Array\n | Float32Array\n | Float64Array;\n\n/**\n * Returns an array of size newSize that starts with the contents of array.\n * Either returns array if it has the correct size, or a new array with zero\n * padding at the end.\n */\nexport function maybePadArray(\n array: T,\n newSize: number,\n): T {\n if (array.length === newSize) {\n return array;\n }\n const newArray = new (array.constructor)(newSize);\n newArray.set(array);\n return newArray;\n}\n\nexport function getFortranOrderStrides(\n size: ArrayLike,\n baseStride = 1,\n) {\n const length = size.length;\n const strides = new Array(length);\n let stride = (strides[0] = baseStride);\n for (let i = 1; i < length; ++i) {\n stride *= size[i - 1];\n strides[i] = stride;\n }\n return strides;\n}\n\n/**\n * Converts an array of shape [majorSize, minorSize] to\n * [minorSize, majorSize].\n */\nexport function transposeArray2d(\n array: T,\n majorSize: number,\n minorSize: number,\n): T {\n const transpose = new (array.constructor)(array.length);\n for (let i = 0; i < majorSize * minorSize; i += minorSize) {\n for (let j = 0; j < minorSize; j++) {\n const index: number = i / minorSize;\n transpose[j * majorSize + index] = array[i + j];\n }\n }\n return transpose;\n}\n\nexport function tile2dArray(\n array: T,\n majorDimension: number,\n minorTiles: number,\n majorTiles: number,\n) {\n const minorDimension = array.length / majorDimension;\n const length = array.length * minorTiles * majorTiles;\n const result: T = new (array.constructor)(length);\n const minorTileStride = array.length * majorTiles;\n const majorTileStride = majorDimension;\n const minorStride = majorDimension * majorTiles;\n for (let minor = 0; minor < minorDimension; ++minor) {\n for (let major = 0; major < majorDimension; ++major) {\n const inputValue = array[minor * majorDimension + major];\n const baseOffset = minor * minorStride + major;\n for (let minorTile = 0; minorTile < minorTiles; ++minorTile) {\n for (let majorTile = 0; majorTile < majorTiles; ++majorTile) {\n result[\n minorTile * minorTileStride +\n majorTile * majorTileStride +\n baseOffset\n ] = inputValue;\n }\n }\n }\n }\n return result;\n}\n\nexport function binarySearch(\n haystack: ArrayLike,\n needle: T,\n compare: (a: T, b: T) => number,\n low = 0,\n high = haystack.length,\n) {\n while (low < high) {\n const mid = (low + high - 1) >> 1;\n const compareResult = compare(needle, haystack[mid]);\n if (compareResult > 0) {\n low = mid + 1;\n } else if (compareResult < 0) {\n high = mid;\n } else {\n return mid;\n }\n }\n return ~low;\n}\n\n/**\n * Returns the index of the element in `haystack` that is closest to `needle`, according to\n * `compare`. If there are multiple elements that are equally close, the index of the first such\n * element encountered is returned. If `haystack` is empty, returns -1.\n */\nexport function findClosestMatchInSortedArray(\n haystack: ArrayLike,\n needle: T,\n compare: (a: T, b: T) => number,\n low = 0,\n high = haystack.length,\n): number {\n let bestIndex = -1;\n let bestDistance = Infinity;\n while (low < high) {\n const mid = (low + high - 1) >> 1;\n const compareResult = compare(needle, haystack[mid]);\n if (compareResult > 0) {\n low = mid + 1;\n } else if (compareResult < 0) {\n high = mid;\n } else {\n return mid;\n }\n const distance = Math.abs(compareResult);\n if (distance < bestDistance) {\n bestDistance = distance;\n bestIndex = mid;\n }\n }\n return bestIndex;\n}\n\n/**\n * Returns the first index in `[begin, end)` for which `predicate` is `true`, or returns `end` if no\n * such index exists.\n *\n * For any index `i` in `(begin, end)`, it must be the case that `predicate(i) >= predicate(i - 1)`.\n */\nexport function binarySearchLowerBound(\n begin: number,\n end: number,\n predicate: (index: number) => boolean,\n): number {\n let count = end - begin;\n while (count > 0) {\n const step = Math.floor(count / 2);\n const i = begin + step;\n if (predicate(i)) {\n count = step;\n } else {\n begin = i + 1;\n count -= step + 1;\n }\n }\n return begin;\n}\n\n/**\n * Returns an array of indices into `input` that equal (under `===`) `value`.\n */\nexport function findMatchingIndices(input: T[], value: T) {\n const out: number[] = [];\n for (let i = 0, length = input.length; i < length; ++i) {\n if (input[i] === value) {\n out.push(i);\n }\n }\n return out;\n}\n\n/**\n * Returns an array of the indices in `[0, ..., max)` not in `indices`.\n */\nexport function getIndicesComplement(indices: number[], max: number) {\n const mask: boolean[] = [];\n mask.length = max;\n for (const i of indices) {\n mask[i] = true;\n }\n return findMatchingIndices(mask, undefined);\n}\n\nexport function arraysEqual(a: ArrayLike, b: ArrayLike) {\n const length = a.length;\n if (b.length !== length) return false;\n for (let i = 0; i < length; ++i) {\n if (a[i] !== b[i]) return false;\n }\n return true;\n}\n\nexport function arraysEqualWithPredicate(\n a: ArrayLike,\n b: ArrayLike,\n elementsEqual: (a: T, b: T) => boolean = (a, b) => a === b,\n) {\n const length = a.length;\n if (b.length !== length) return false;\n for (let i = 0; i < length; ++i) {\n if (!elementsEqual(a[i], b[i])) return false;\n }\n return true;\n}\n\nexport function getInsertPermutation(\n n: number,\n sourceIndex: number,\n targetIndex: number,\n) {\n const newToOld: number[] = [];\n if (targetIndex === sourceIndex) {\n for (let i = 0; i < n; ++i) {\n newToOld[i] = i;\n }\n return newToOld;\n }\n newToOld[targetIndex] = sourceIndex;\n for (let oldDim = 0, newDim = 0; oldDim < n; ) {\n if (oldDim === sourceIndex) {\n ++oldDim;\n continue;\n }\n if (newDim === targetIndex) {\n ++newDim;\n }\n newToOld[newDim++] = oldDim++;\n }\n return newToOld;\n}\n\nexport function scatterUpdate<\n T,\n Dest extends { [index: number]: T },\n Source extends { readonly [index: number]: T },\n>(dest: Dest, source: Source, indices: ArrayLike): Dest {\n for (\n let sourceIndex = 0, length = indices.length;\n sourceIndex < length;\n ++sourceIndex\n ) {\n const destIndex = indices[sourceIndex];\n if (destIndex === -1) continue;\n dest[destIndex] = source[sourceIndex];\n }\n return dest;\n}\n\nexport function gatherUpdate<\n T,\n Dest extends { [index: number]: T },\n Source extends { readonly [index: number]: T },\n>(dest: Dest, source: Source, indices: ArrayLike): Dest {\n for (\n let destIndex = 0, length = indices.length;\n destIndex < length;\n ++destIndex\n ) {\n const sourceIndex = indices[destIndex];\n if (sourceIndex === -1) continue;\n dest[destIndex] = source[sourceIndex];\n }\n return dest;\n}\n\nexport function transposeNestedArrays(x: T[][]) {\n const result: T[][] = [];\n for (\n let outerIndex = 0, outerLength = x.length;\n outerIndex < outerLength;\n ++outerIndex\n ) {\n const inner = x[outerIndex];\n for (\n let innerIndex = 0, innerLength = inner.length;\n innerIndex < innerLength;\n ++innerIndex\n ) {\n let resultInner = result[innerIndex];\n if (resultInner === undefined) {\n resultInner = result[innerIndex] = [];\n }\n resultInner.push(inner[innerIndex]);\n }\n }\n return result;\n}\n\nexport interface ArraySpliceOp {\n retainCount: number;\n deleteCount: number;\n insertCount: number;\n}\n\nexport function spliceArray(\n array: T[],\n splices: readonly Readonly[],\n) {\n const parts: T[][] = [];\n let origOffset = 0;\n for (let i = 0, numSplices = splices.length; i < numSplices; ++i) {\n const { retainCount, deleteCount, insertCount } = splices[i];\n if (retainCount !== 0) {\n parts.push(array.slice(origOffset, origOffset + retainCount));\n origOffset += retainCount;\n }\n origOffset += deleteCount;\n if (insertCount !== 0) {\n parts.push(new Array(insertCount));\n }\n }\n const origLength = array.length;\n if (origOffset !== origLength) {\n parts.push(array.slice(origOffset));\n }\n return new Array(0).concat(...parts);\n}\n\nexport function getMergeSplices(\n oldArray: readonly T[],\n newArray: readonly T[],\n compare: (a: T, b: T) => number,\n): ArraySpliceOp[] {\n const splices: ArraySpliceOp[] = [];\n let oldIndex = 0;\n let newIndex = 0;\n const oldCount = oldArray.length;\n const newCount = newArray.length;\n while (oldIndex < oldCount && newIndex < newCount) {\n let c: number;\n const oldValue = oldArray[oldIndex];\n const newValue = newArray[newIndex];\n c = compare(oldValue, newValue);\n if (c === 0) {\n let retainCount = 1;\n ++oldIndex;\n ++newIndex;\n while (\n oldIndex < oldCount &&\n newIndex < newCount &&\n (c = compare(oldArray[oldIndex], newArray[newIndex])) === 0\n ) {\n ++retainCount;\n ++oldIndex;\n ++newIndex;\n }\n splices.push({ retainCount, deleteCount: 0, insertCount: 0 });\n continue;\n }\n if (c < 0) {\n let deleteCount = 1;\n while (\n ++oldIndex < oldCount &&\n (c = compare(oldArray[oldIndex], newValue)) < 0\n ) {\n ++deleteCount;\n }\n splices.push({ retainCount: 0, deleteCount, insertCount: 0 });\n continue;\n }\n if (c > 0) {\n let insertCount = 1;\n while (\n ++newIndex < newCount &&\n (c = compare(oldValue, newArray[newIndex])) > 0\n ) {\n ++insertCount;\n }\n splices.push({ retainCount: 0, deleteCount: 0, insertCount });\n }\n }\n if (oldIndex < oldCount || newIndex < newCount) {\n splices.push({\n retainCount: 0,\n deleteCount: oldCount - oldIndex,\n insertCount: newCount - newIndex,\n });\n }\n return splices;\n}\n\nexport function getFixedOrderMergeSplices(\n oldArray: readonly T[],\n newArray: readonly T[],\n equal: (a: T, b: T) => boolean,\n): ArraySpliceOp[] {\n const splices: ArraySpliceOp[] = [];\n let oldIndex = 0;\n let newIndex = 0;\n const oldCount = oldArray.length;\n const newCount = newArray.length;\n while (oldIndex < oldCount) {\n let retainCount = 0;\n while (\n oldIndex < oldCount &&\n newIndex < newCount &&\n equal(oldArray[oldIndex], newArray[newIndex])\n ) {\n ++retainCount;\n ++oldIndex;\n ++newIndex;\n }\n if (retainCount !== 0) {\n splices.push({ retainCount, deleteCount: 0, insertCount: 0 });\n }\n let deleteCount = 0;\n while (\n oldIndex < oldCount &&\n (newIndex === newCount || !equal(oldArray[oldIndex], newArray[newIndex]))\n ) {\n ++deleteCount;\n ++oldIndex;\n }\n if (deleteCount !== 0) {\n splices.push({ retainCount: 0, deleteCount, insertCount: 0 });\n }\n }\n if (newIndex !== newCount) {\n splices.push({\n retainCount: 0,\n deleteCount: 0,\n insertCount: newCount - newIndex,\n });\n }\n return splices;\n}\n\nexport function mergeSequences(\n aCount: number,\n bCount: number,\n compare: (a: number, b: number) => number,\n aCallback: (a: number) => void,\n bCallback: (b: number) => void,\n abCallback: (a: number, b: number) => void,\n) {\n let a = 0;\n let b = 0;\n if (aCount !== 0 && bCount !== 0) {\n while (true) {\n const x = compare(a, b);\n if (x < 0) {\n aCallback(a);\n if (++a === aCount) break;\n } else if (x > 0) {\n bCallback(b);\n if (++b === bCount) break;\n } else {\n abCallback(a, b);\n ++a;\n ++b;\n if (a === aCount || b === bCount) break;\n }\n }\n }\n while (a < aCount) {\n aCallback(a);\n ++a;\n }\n while (b < bCount) {\n bCallback(b);\n ++b;\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file\n * Cancellation token system with similarity to the cancellation_token in Microsoft's PPL.\n */\n\n/**\n * Interface used by cancelable operations to monitor whether cancellation has occurred.\n *\n * Note that this interface does not provide any way to trigger cancellation; for that,\n * CancellationTokenSource is used.\n */\nexport interface CancellationToken {\n /**\n * Indicates whether cancellation has occurred.\n */\n readonly isCanceled: boolean;\n\n /**\n * Add a cancellation handler function. The handler will be invoked synchronously if\n * this.isCanceled === true. Otherwise, it will be invoked synchronously upon cancellation,\n * unless it is removed prior to cancellation.\n *\n * The handler function must not throw any exceptions when called.\n *\n * @precondition The handler function must not already be registered.\n *\n * @param handler The handler function to add.\n *\n * @return A function that unregisters the handler.\n */\n add(handler: () => void): () => void;\n\n /**\n * Unregister a cancellation handler function. If this.isCanceled, or the specified handler\n * function has not been registered, then this function has no effect.\n */\n remove(handler: () => void): void;\n}\n\nexport class CancellationError extends Error {\n name = \"CancellationError\";\n message = \"CANCELED\";\n toString() {\n return \"CANCELED\";\n }\n}\n\n/**\n * Singleton instance of CancellationError thrown to indicate cancellation.\n */\nexport const CANCELED = new CancellationError();\n\n/**\n * Throws CANCELED if token.isCanceled === true.\n */\nexport function throwIfCanceled(token: CancellationToken) {\n if (token.isCanceled === true) {\n throw CANCELED;\n }\n}\n\nconst noopFunction = () => {};\n\n/**\n * CancellationToken that cannot be canceled. This can be passed to operations that require a\n * CancellationToken but will not need to be canceled.\n */\nexport const uncancelableToken: CancellationToken = {\n isCanceled: false,\n add: () => noopFunction,\n remove: noopFunction,\n};\n\n/**\n * Class that can be used to trigger cancellation.\n */\nexport class CancellationTokenSource implements CancellationToken {\n /**\n * Trigger cancellation.\n *\n * If this.isCanceled === false, then each registered cancellation handler is invoked\n * synchronously.\n */\n cancel() {\n const { handlers } = this;\n if (handlers !== null) {\n this.handlers = null;\n if (handlers !== undefined) {\n for (const handler of handlers) {\n handler();\n }\n }\n }\n }\n\n get isCanceled() {\n return this.handlers === null;\n }\n\n private handlers: Set<() => void> | undefined | null;\n\n add(handler: () => void) {\n let { handlers } = this;\n if (handlers === null) {\n handler();\n return noopFunction;\n }\n if (handlers === undefined) {\n handlers = this.handlers = new Set<() => void>();\n }\n handlers.add(handler);\n return () => {\n this.remove(handler);\n };\n }\n\n remove(handler: () => void) {\n const { handlers } = this;\n if (handlers != null) {\n handlers.delete(handler);\n }\n }\n}\n\n/**\n * Creates a CancellationToken corresponding to an asynchronous process with multiple consumers. It\n * is cancelled only when the cancellation tokens corresponding to all of the consumers have been\n * cancelled.\n */\nexport class MultipleConsumerCancellationTokenSource extends CancellationTokenSource {\n private consumers = new Set();\n\n addConsumer(cancellationToken: CancellationToken = uncancelableToken) {\n const { consumers } = this;\n if (consumers.has(cancellationToken) || cancellationToken.isCanceled) {\n return;\n }\n consumers.add(cancellationToken);\n cancellationToken.add(() => {\n consumers.delete(cancellationToken);\n if (consumers.size === 0) {\n this.cancel();\n }\n });\n }\n}\n\n/**\n * Creates a promise and a dependent cancellation token.\n *\n * The dependent cancellation token will be canceled if the specified `cancellationToken` is\n * canceled while the promise is pending.\n *\n * @param cancellationToken The token that provides notification of cancellation.\n * @param executor The executor passed the resolve and reject functions for the promise, as well as\n * the dependent cancellation token. If cancellation occurs after either resolve or reject is\n * called, then the dependent token is not cancelled.\n *\n * @returns A new Promise.\n */\nexport function makeCancelablePromise(\n cancellationToken: CancellationToken,\n executor: (\n resolve: (value: T | Promise) => void,\n reject: (error: any) => void,\n token: CancellationToken,\n ) => void,\n) {\n return new Promise((resolve, reject) => {\n if (cancellationToken === uncancelableToken) {\n executor(resolve, reject, uncancelableToken);\n return;\n }\n const scopedToken = new CancellationTokenSource();\n const unregister = cancellationToken.add(() => {\n scopedToken.cancel();\n });\n executor(\n (value) => {\n unregister();\n resolve(value);\n },\n (error) => {\n unregister();\n reject(error);\n },\n scopedToken,\n );\n });\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport interface Disposable {\n dispose: () => void;\n}\n\nexport type Disposer = Disposable | (() => void);\n\nconst DEBUG_REF_COUNTS = false;\n\nexport function invokeDisposer(disposer: Disposer) {\n if (typeof disposer === \"object\") {\n disposer.dispose();\n } else {\n disposer();\n }\n}\n\nexport function invokeDisposers(disposers: Disposer[]) {\n for (let i = disposers.length; i > 0; --i) {\n invokeDisposer(disposers[i - 1]);\n }\n}\n\nexport function registerEventListener(\n target: EventTarget,\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | AddEventListenerOptions,\n) {\n target.addEventListener(type, listener, options);\n return () => target.removeEventListener(type, listener, options);\n}\n\nexport class RefCounted implements Disposable {\n public refCount = 1;\n wasDisposed: boolean | undefined;\n private disposers: Disposer[];\n addRef() {\n ++this.refCount;\n return this;\n }\n disposedStacks: any;\n dispose() {\n if (DEBUG_REF_COUNTS) {\n (this.disposedStacks = this.disposedStacks || []).push(new Error().stack);\n }\n if (--this.refCount !== 0) {\n return;\n }\n this.refCountReachedZero();\n }\n\n protected refCountReachedZero() {\n this.disposed();\n const { disposers } = this;\n if (disposers !== undefined) {\n invokeDisposers(disposers);\n this.disposers = undefined;\n }\n this.wasDisposed = true;\n }\n disposed() {}\n registerDisposer(f: T): T {\n const { disposers } = this;\n if (disposers == null) {\n this.disposers = [f];\n } else {\n disposers.push(f);\n }\n return f;\n }\n unregisterDisposer(f: T): T {\n const { disposers } = this;\n if (disposers != null) {\n const index = disposers.indexOf(f);\n if (index !== -1) {\n disposers.splice(index, 1);\n }\n }\n return f;\n }\n registerEventListener(\n target: EventTarget,\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | AddEventListenerOptions,\n ) {\n this.registerDisposer(\n registerEventListener(target, type, listener, options),\n );\n }\n registerCancellable void }>(cancellable: T) {\n this.registerDisposer(() => {\n cancellable.cancel();\n });\n return cancellable;\n }\n}\n\nexport class RefCountedValue extends RefCounted {\n constructor(public value: T) {\n super();\n }\n}\n\n/**\n * A variable of this type is associated with an increment of the reference count. If a function\n * parameter is declared with this type, then callers must donate a reference count.\n */\nexport type Owned = T;\n\n/**\n * A variable of this type is not associated with an increment of the reference count.\n */\nexport type Borrowed = T;\n\nexport function disposableOnce(value: Disposer | undefined) {\n return () => {\n if (value !== undefined) {\n const x = value;\n value = undefined;\n invokeDisposer(x);\n }\n };\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { mat3 } from \"gl-matrix\";\nimport { mat4, quat, vec3, vec4 } from \"gl-matrix\";\nimport type { TypedArray } from \"#src/util/array.js\";\nimport { findMatchingIndices } from \"#src/util/array.js\";\n\nexport { mat2, mat3, mat4, quat, vec2, vec3, vec4 } from \"gl-matrix\";\n\nexport const identityMat4 = mat4.create();\n\nexport const AXES_NAMES = [\"x\", \"y\", \"z\"];\n\nexport const kAxes = [\n vec3.fromValues(1, 0, 0),\n vec3.fromValues(0, 1, 0),\n vec3.fromValues(0, 0, 1),\n];\nexport const kZeroVec = vec3.fromValues(0, 0, 0);\nexport const kZeroVec4 = vec4.fromValues(0, 0, 0, 0);\nexport const kOneVec = vec3.fromValues(1, 1, 1);\nexport const kInfinityVec = vec3.fromValues(Infinity, Infinity, Infinity);\nexport const kIdentityQuat = quat.create();\n\nexport function prod3(x: ArrayLike) {\n return x[0] * x[1] * x[2];\n}\n\nexport function prod4(x: ArrayLike) {\n return x[0] * x[1] * x[2] * x[3];\n}\n\n/**\n * Implements a one-to-one conversion from Vec3 to string, suitable for use a Map key.\n *\n * Specifically, returns the string representation of the 3 values separated by commas.\n */\nexport function vec3Key(x: ArrayLike) {\n return `${x[0]},${x[1]},${x[2]}`;\n}\n\n/**\n * Transforms `a` by a 180-degree rotation about X, stores result in `out`.\n */\nexport function quatRotateX180(out: quat, a: quat) {\n const x = a[0];\n const y = a[1];\n const z = a[2];\n const w = a[3];\n out[0] = w;\n out[1] = z;\n out[2] = -y;\n out[3] = -x;\n}\n\n/**\n * Transforms `a` by a 180-degree rotation about Y, stores result in `out`.\n */\nexport function quatRotateY180(out: quat, a: quat) {\n const x = a[0];\n const y = a[1];\n const z = a[2];\n const w = a[3];\n out[0] = -z;\n out[1] = w;\n out[2] = x;\n out[3] = -y;\n}\n\n/**\n * Transforms `a` by a 180-degree rotation about Z, stores result in `out`.\n */\nexport function quatRotateZ180(out: quat, a: quat) {\n const x = a[0];\n const y = a[1];\n const z = a[2];\n const w = a[3];\n out[0] = y;\n out[1] = -x;\n out[2] = w;\n out[3] = -z;\n}\n\n/**\n * Transforms a vector `a` by a homogenous transformation matrix `m`. The translation component of\n * `m` is ignored.\n */\nexport function transformVectorByMat4(out: vec3, a: vec3, m: mat4) {\n const x = a[0];\n const y = a[1];\n const z = a[2];\n out[0] = m[0] * x + m[4] * y + m[8] * z;\n out[1] = m[1] * x + m[5] * y + m[9] * z;\n out[2] = m[2] * x + m[6] * y + m[10] * z;\n return out;\n}\n\n/**\n * Transforms a vector `a` by the transpose of a homogenous transformation matrix `m`. The\n * translation component of `m` is ignored.\n */\nexport function transformVectorByMat4Transpose(out: vec3, a: vec3, m: mat4) {\n const x = a[0];\n const y = a[1];\n const z = a[2];\n out[0] = m[0] * x + m[1] * y + m[2] * z;\n out[1] = m[4] * x + m[5] * y + m[6] * z;\n out[2] = m[8] * x + m[9] * y + m[10] * z;\n return out;\n}\n\nexport function translationRotationScaleZReflectionToMat4(\n out: mat4,\n translation: vec3,\n rotation: quat,\n scale: vec3,\n zReflection: number,\n) {\n const temp: Float32Array = out;\n out[0] = scale[0];\n out[1] = scale[1];\n out[2] = scale[2] * zReflection;\n return mat4.fromRotationTranslationScale(\n out,\n rotation,\n translation,\n temp,\n );\n}\n\n/**\n * Returns the value of `t` that minimizes `(p - (a + t * (b - a)))`.\n */\nexport function findClosestParameterizedLinePosition(\n a: Float32Array,\n b: Float32Array,\n p: Float32Array,\n) {\n // http://mathworld.wolfram.com/Point-LineDistance3-Dimensional.html\n // Compute t: -dot(a-p, b-a) / |b - a|^2\n const rank = p.length;\n let denominator = 0;\n for (let i = 0; i < rank; ++i) {\n denominator += (a[i] - b[i]) ** 2;\n }\n let numerator = 0;\n for (let i = 0; i < rank; ++i) {\n const aValue = a[i];\n numerator -= (aValue - p[i]) * (b[i] - aValue);\n }\n return numerator / Math.max(denominator, 1e-6);\n}\n\n/**\n * Sets `out` to the position on the line segment `[a, b]` closest to `p`.\n */\nexport function projectPointToLineSegment(\n out: Float32Array,\n a: Float32Array,\n b: Float32Array,\n p: Float32Array,\n) {\n const rank = out.length;\n let t = findClosestParameterizedLinePosition(a, b, p);\n t = Math.max(0.0, Math.min(1.0, t));\n for (let i = 0; i < rank; ++i) {\n const aValue = a[i];\n out[i] = aValue + t * (b[i] - aValue);\n }\n return out;\n}\n\nexport function mat3FromMat4(out: mat3, m: mat4) {\n const m00 = m[0];\n const m01 = m[1];\n const m02 = m[2];\n const m10 = m[4];\n const m11 = m[5];\n const m12 = m[6];\n const m20 = m[8];\n const m21 = m[9];\n const m22 = m[10];\n out[0] = m00;\n out[1] = m01;\n out[2] = m02;\n out[3] = m10;\n out[4] = m11;\n out[5] = m12;\n out[6] = m20;\n out[7] = m21;\n out[8] = m22;\n return out;\n}\n\n/**\n * Extracts the left, right, bottom, top, near, far clipping planes from `projectionMat`.\n * @param out Row-major array of shape `(6, 4)` specifying for each of the left, right, bottom, top,\n * near, far clipping planes the `a`, `b`, `c`, `d` coefficients such that\n * `0 < a * x + b * y + c * z + d` if the point `x, y, z` is inside the half-space of the\n * clipping plane.\n * @param m Projection matrix\n */\nexport function getFrustrumPlanes(out: Float32Array, m: mat4): Float32Array {\n // http://web.archive.org/web/20120531231005/http://crazyjoke.free.fr/doc/3D/plane%20extraction.pdf\n const m00 = m[0];\n const m10 = m[1];\n const m20 = m[2];\n const m30 = m[3];\n const m01 = m[4];\n const m11 = m[5];\n const m21 = m[6];\n const m31 = m[7];\n const m02 = m[8];\n const m12 = m[9];\n const m22 = m[10];\n const m32 = m[11];\n const m03 = m[12];\n const m13 = m[13];\n const m23 = m[14];\n const m33 = m[15];\n\n out[0] = m30 + m00; // left: a\n out[1] = m31 + m01; // left: b\n out[2] = m32 + m02; // left: c\n out[3] = m33 + m03; // left: d\n\n out[4] = m30 - m00; // right: a\n out[5] = m31 - m01; // right: b\n out[6] = m32 - m02; // right: c\n out[7] = m33 - m03; // right: d\n\n out[8] = m30 + m10; // bottom: a\n out[9] = m31 + m11; // bottom: b\n out[10] = m32 + m12; // bottom: c\n out[11] = m33 + m13; // bottom: d\n\n out[12] = m30 - m10; // top: a\n out[13] = m31 - m11; // top: b\n out[14] = m32 - m12; // top: c\n out[15] = m33 - m13; // top: d\n\n const nearA = m30 + m20; // near: a\n const nearB = m31 + m21; // near: b\n const nearC = m32 + m22; // near: c\n const nearD = m33 + m23; // near: d\n\n const farA = m30 - m20; // far: a\n const farB = m31 - m21; // far: b\n const farC = m32 - m22; // far: c\n const farD = m33 - m23; // far: d\n\n // Normalize near plane\n const nearNorm = Math.sqrt(nearA ** 2 + nearB ** 2 + nearC ** 2);\n out[16] = nearA / nearNorm;\n out[17] = nearB / nearNorm;\n out[18] = nearC / nearNorm;\n out[19] = nearD / nearNorm;\n\n // Also normalize far plane\n const farNorm = Math.sqrt(farA ** 2 + farB ** 2 + farC ** 2);\n out[20] = farA / farNorm;\n out[21] = farB / farNorm;\n out[22] = farC / farNorm;\n out[23] = farD / farNorm;\n\n return out;\n}\n\n/**\n * Checks whether the specified axis-aligned bounding box (AABB) intersects the view frustrum.\n *\n * @param clippingPlanes Array of length 24 specifying the clipping planes of the view frustrum, as\n * computed by `getFrustrumPlanes`\n */\nexport function isAABBVisible(\n xLower: number,\n yLower: number,\n zLower: number,\n xUpper: number,\n yUpper: number,\n zUpper: number,\n clippingPlanes: Float32Array,\n) {\n for (let i = 0; i < 6; ++i) {\n const a = clippingPlanes[i * 4];\n const b = clippingPlanes[i * 4 + 1];\n const c = clippingPlanes[i * 4 + 2];\n const d = clippingPlanes[i * 4 + 3];\n const sum =\n Math.max(a * xLower, a * xUpper) +\n Math.max(b * yLower, b * yUpper) +\n Math.max(c * zLower, c * zUpper) +\n d;\n if (sum < 0) {\n return false;\n }\n }\n return true;\n}\n\nexport function isAABBIntersectingPlane(\n xLower: number,\n yLower: number,\n zLower: number,\n xUpper: number,\n yUpper: number,\n zUpper: number,\n clippingPlanes: Float32Array,\n) {\n for (let i = 0; i < 4; ++i) {\n const a = clippingPlanes[i * 4];\n const b = clippingPlanes[i * 4 + 1];\n const c = clippingPlanes[i * 4 + 2];\n const d = clippingPlanes[i * 4 + 3];\n const sum =\n Math.max(a * xLower, a * xUpper) +\n Math.max(b * yLower, b * yUpper) +\n Math.max(c * zLower, c * zUpper) +\n d;\n if (sum < 0) {\n return false;\n }\n }\n {\n const i = 5;\n const a = clippingPlanes[i * 4];\n const b = clippingPlanes[i * 4 + 1];\n const c = clippingPlanes[i * 4 + 2];\n const d = clippingPlanes[i * 4 + 3];\n const maxSum =\n Math.max(a * xLower, a * xUpper) +\n Math.max(b * yLower, b * yUpper) +\n Math.max(c * zLower, c * zUpper);\n const minSum =\n Math.min(a * xLower, a * xUpper) +\n Math.min(b * yLower, b * yUpper) +\n Math.min(c * zLower, c * zUpper);\n const epsilon = Math.abs(d) * 1e-6;\n if (minSum > -d + epsilon || maxSum < -d - epsilon) return false;\n }\n return true;\n}\n\n/**\n * Returns the list (in sorted order) of input dimensions that depend on any of the specified output\n * dimensions.\n */\nexport function getDependentTransformInputDimensions(\n transform: Float32Array | Float64Array,\n rank: number,\n outputDimensions: readonly number[],\n transpose = false,\n): number[] {\n const numOutputDimensions = outputDimensions.length;\n const isDependentInputDimension: boolean[] = [];\n const inputStride = transpose ? 1 : rank + 1;\n const outputStride = transpose ? rank + 1 : 1;\n for (let i = 0; i < numOutputDimensions; ++i) {\n const outputDim = outputDimensions[i];\n for (let inputDim = 0; inputDim < rank; ++inputDim) {\n if (transform[inputDim * inputStride + outputDim * outputStride] !== 0) {\n isDependentInputDimension[inputDim] = true;\n }\n }\n }\n return findMatchingIndices(isDependentInputDimension, true);\n}\n\nexport function scaleMat3Input(out: mat3, input: mat3, scales: TypedArray) {\n for (let j = 0; j < 3; ++j) {\n const s = scales[j];\n for (let i = 0; i < 3; ++i) {\n out[i + j * 3] = s * input[i + j * 3];\n }\n }\n return out;\n}\n\nexport function scaleMat3Output(out: mat3, input: mat3, scales: TypedArray) {\n for (let i = 0; i < 3; ++i) {\n const s = scales[i];\n for (let j = 0; j < 3; ++j) {\n out[i + j * 3] = s * input[i + j * 3];\n }\n }\n return out;\n}\n\nexport function getViewFrustrumVolume(projectionMat: mat4) {\n if (projectionMat[15] === 1) {\n // orthographic projection\n const depth = 2 / Math.abs(projectionMat[10]);\n const width = 2 / Math.abs(projectionMat[0]);\n const height = 2 / Math.abs(projectionMat[5]);\n return width * height * depth;\n }\n // perspective projection\n // a = (far + near) / (near - far);\n // b = 2 * far * near / (near - far);\n const a = projectionMat[10];\n const b = projectionMat[14];\n const near = (2 * b) / (2 * a - 2);\n const far = ((a - 1) * near) / (a + 1);\n\n const baseArea = 4 / (projectionMat[0] * projectionMat[5]);\n return (baseArea / 3) * (Math.abs(far) ** 3 - Math.abs(near) ** 3);\n}\n\nexport function getViewFrustrumDepthRange(projectionMat: mat4) {\n if (projectionMat[15] === 1) {\n // orthographic projection\n const depth = 2 / Math.abs(projectionMat[10]);\n return depth;\n }\n // perspective projection\n // a = (far + near) / (near - far);\n // b = 2 * far * near / (near - far);\n const a = projectionMat[10];\n const b = projectionMat[14];\n const near = (2 * b) / (2 * a - 2);\n const far = ((a - 1) * near) / (a + 1);\n const depth = Math.abs(far - near);\n return depth;\n}\n\n// Ensures the z output is 0. Useful for disabling depth clipping.\nexport function disableZProjection(mat: mat4) {\n mat[2] = 0;\n mat[6] = 0;\n mat[10] = 0;\n mat[14] = 0;\n return mat;\n}\n\nconst tempVec3 = vec3.create();\n\n// Determines the bounding box in world coordinates of the view frustrum for a given view-projection\n// matrix.\n//\n// https://gamedev.stackexchange.com/questions/29999/how-do-i-create-a-bounding-frustum-from-a-view-projection-matrix\nexport function getViewFrustrumWorldBounds(\n invViewProjectionMat: mat4,\n bounds: Float32Array,\n) {\n bounds[0] = bounds[1] = bounds[2] = Number.POSITIVE_INFINITY;\n bounds[3] = bounds[4] = bounds[5] = Number.NEGATIVE_INFINITY;\n for (let i = 0; i < 8; ++i) {\n tempVec3[0] = 2 * (i & 1) - 1;\n tempVec3[1] = 2 * ((i >>> 1) & 1) - 1;\n tempVec3[2] = 2 * ((i >>> 2) & 1) - 1;\n vec3.transformMat4(tempVec3, tempVec3, invViewProjectionMat);\n for (let j = 0; j < 3; ++j) {\n const x = tempVec3[j];\n bounds[j] = Math.min(bounds[j], x);\n bounds[j + 3] = Math.max(bounds[j + 3], x);\n }\n }\n}\n","// Inject google tag manager script if `NEUROGLANCER_GOOGLE_TAG_MANAGER` is defined.\ndeclare const NEUROGLANCER_GOOGLE_TAG_MANAGER: string | undefined;\n\nif (typeof NEUROGLANCER_GOOGLE_TAG_MANAGER !== \"undefined\") {\n const l = \"dataLayer\";\n const i = NEUROGLANCER_GOOGLE_TAG_MANAGER;\n (window as any)[l] = (window as any)[l] || [];\n (window as any)[l].push({\n \"gtm.start\": new Date().getTime(),\n event: \"gtm.js\",\n });\n const script = document.createElement(\"script\");\n script.async = true;\n script.src = `https://www.googletagmanager.com/gtm.js?id=${i}`;\n document.head.appendChild(script);\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { CancellationToken } from \"#src/util/cancellation.js\";\nimport { CANCELED, uncancelableToken } from \"#src/util/cancellation.js\";\nimport { Uint64 } from \"#src/util/uint64.js\";\n\nexport class HttpError extends Error {\n url: string;\n status: number;\n statusText: string;\n response?: Response;\n\n constructor(\n url: string,\n status: number,\n statusText: string,\n response?: Response,\n ) {\n let message = `Fetching ${JSON.stringify(\n url,\n )} resulted in HTTP error ${status}`;\n if (statusText) {\n message += `: ${statusText}`;\n }\n message += \".\";\n super(message);\n this.name = \"HttpError\";\n this.message = message;\n this.url = url;\n this.status = status;\n this.statusText = statusText;\n if (response) {\n this.response = response;\n }\n }\n\n static fromResponse(response: Response) {\n return new HttpError(\n response.url,\n response.status,\n response.statusText,\n response,\n );\n }\n\n static fromRequestError(input: RequestInfo, error: unknown) {\n if (error instanceof TypeError) {\n let url: string;\n if (typeof input === \"string\") {\n url = input;\n } else {\n url = input.url;\n }\n return new HttpError(url, 0, \"Network or CORS error\");\n }\n return error;\n }\n}\n\nconst maxAttempts = 32;\nconst minDelayMilliseconds = 500;\nconst maxDelayMilliseconds = 10000;\n\nexport function pickDelay(attemptNumber: number): number {\n // If `attemptNumber == 0`, delay is a random number of milliseconds between\n // `[minDelayMilliseconds, minDelayMilliseconds*2]`. The lower and upper bounds of the interval\n // double with each successive attempt, up to the limit of\n // `[maxDelayMilliseconds/2,maxDelayMilliseconds]`.\n return (\n Math.min(\n 2 ** attemptNumber * minDelayMilliseconds,\n maxDelayMilliseconds / 2,\n ) *\n (1 + Math.random())\n );\n}\n\n/**\n * Issues a `fetch` request.\n *\n * If the request fails due to an HTTP status outside `[200, 300)`, throws an `HttpError`. If the\n * request fails due to a network or CORS restriction, throws an `HttpError` with a `status` of `0`.\n *\n * If the request fails due to a transient error (429, 503, 504), retry.\n */\nexport async function fetchOk(\n input: RequestInfo,\n init?: RequestInit,\n): Promise {\n for (let requestAttempt = 0; ; ) {\n if (init?.signal?.aborted) {\n throw CANCELED;\n }\n let response: Response;\n try {\n response = await fetch(input, init);\n } catch (error) {\n throw HttpError.fromRequestError(input, error);\n }\n if (!response.ok) {\n const { status } = response;\n if (status === 429 || status === 503 || status === 504) {\n // 429: Too Many Requests. Retry.\n // 503: Service unavailable. Retry.\n // 504: Gateway timeout. Can occur if the server takes too long to reply. Retry.\n if (++requestAttempt !== maxAttempts) {\n await new Promise((resolve) =>\n setTimeout(resolve, pickDelay(requestAttempt - 1)),\n );\n continue;\n }\n }\n throw HttpError.fromResponse(response);\n }\n return response;\n }\n}\n\nexport function responseArrayBuffer(response: Response): Promise {\n return response.arrayBuffer();\n}\n\nexport function responseJson(response: Response): Promise {\n return response.json();\n}\n\nexport type ResponseTransform = (response: Response) => Promise;\n\n/**\n * Issues a `fetch` request in the same way as `fetchOk`, and returns the result of the promise\n * returned by `transformResponse`.\n *\n * Additionally, the request may be cancelled through `cancellationToken`.\n *\n * The `transformResponse` function should not do anything with the `Response` object after its\n * result becomes ready; otherwise, cancellation may not work as expected.\n */\nexport async function cancellableFetchOk(\n input: RequestInfo,\n init: RequestInit,\n transformResponse: ResponseTransform,\n cancellationToken: CancellationToken = uncancelableToken,\n): Promise {\n if (cancellationToken === uncancelableToken) {\n const response = await fetchOk(input, init);\n return await transformResponse(response);\n }\n const abortController = new AbortController();\n const unregisterCancellation = cancellationToken.add(() =>\n abortController.abort(),\n );\n try {\n const response = await fetchOk(input, {\n ...init,\n signal: abortController.signal,\n });\n return await transformResponse(response);\n } finally {\n unregisterCancellation();\n }\n}\n\nconst tempUint64 = new Uint64();\n\nexport function getByteRangeHeader(\n startOffset: Uint64 | number,\n endOffset: Uint64 | number,\n) {\n let endOffsetStr: string;\n if (typeof endOffset === \"number\") {\n endOffsetStr = `${endOffset - 1}`;\n } else {\n Uint64.decrement(tempUint64, endOffset);\n endOffsetStr = tempUint64.toString();\n }\n return { Range: `bytes=${startOffset}-${endOffsetStr}` };\n}\n\nexport function parseUrl(url: string): {\n protocol: string;\n host: string;\n path: string;\n} {\n const urlProtocolPattern = /^([^:/]+):\\/\\/([^/]+)((?:\\/.*)?)$/;\n const match = url.match(urlProtocolPattern);\n if (match === null) {\n throw new Error(`Invalid URL: ${JSON.stringify(url)}`);\n }\n return { protocol: match[1], host: match[2], path: match[3] };\n}\n\nexport function isNotFoundError(e: any) {\n if (!(e instanceof HttpError)) return false;\n // Treat CORS errors (0) or 403 as not found. S3 returns 403 if the file does not exist because\n // permissions are per-file.\n return e.status === 0 || e.status === 403 || e.status === 404;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { WritableArrayLike } from \"#src/util/array.js\";\nimport { vec3 } from \"#src/util/geom.js\";\n\nexport function verifyFloat(obj: any): number {\n const t = typeof obj;\n if (t === \"number\" || t === \"string\") {\n const x = parseFloat(\"\" + obj);\n if (!Number.isNaN(x)) {\n return x;\n }\n }\n throw new Error(\n `Expected floating-point number, but received: ${JSON.stringify(obj)}.`,\n );\n}\n\nexport function verifyFiniteFloat(obj: any): number {\n const x = verifyFloat(obj);\n if (Number.isFinite(x)) {\n return x;\n }\n throw new Error(`Expected finite floating-point number, but received: ${x}.`);\n}\n\nexport function verifyFiniteNonNegativeFloat(obj: any): number {\n const x = verifyFloat(obj);\n if (Number.isFinite(x) && x >= 0) {\n return x;\n }\n throw new Error(\n `Expected finite non-negative floating-point number, but received: ${x}.`,\n );\n}\n\nexport function verifyFinitePositiveFloat(obj: any): number {\n const x = verifyFiniteFloat(obj);\n if (x > 0) {\n return x;\n }\n throw new Error(\n `Expected positive finite floating-point number, but received: ${x}.`,\n );\n}\n\nexport function makeVerifyNumberInInterval(minValue: number, maxValue: number) {\n return (obj: any) => {\n const x = verifyFloat(obj);\n if (x >= minValue && x <= maxValue) {\n return x;\n }\n throw new Error(\n `Expected floating-point number in range [${minValue}, ${maxValue}], but received: ${x}.`,\n );\n };\n}\n\nexport function parseXYZ>(\n out: A,\n obj: any,\n validator: (x: any) => number = verifyFloat,\n): A {\n verifyObject(obj);\n out[0] = out[1] = out[2] = 0;\n for (const key of Object.keys(obj)) {\n switch (key) {\n case \"x\":\n out[0] = validator(obj[key]);\n break;\n case \"y\":\n out[1] = validator(obj[key]);\n break;\n case \"z\":\n out[2] = validator(obj[key]);\n break;\n default:\n throw new Error(\n `Expected object to have keys ['x', 'y', 'z'], but received: ${JSON.stringify(\n obj,\n )}.`,\n );\n }\n }\n return out;\n}\n\nexport function parseFiniteVec>(\n out: U,\n obj: any[],\n) {\n const length = out.length;\n if (!Array.isArray(obj) || obj.length !== length) {\n throw new Error(\"Incompatible sizes\");\n }\n\n for (let i = 0; i < length; ++i) {\n if (!Number.isFinite(parseFloat(obj[i]))) {\n throw new Error(\"Non-finite value.\");\n }\n }\n for (let i = 0; i < length; ++i) {\n out[i] = parseFloat(obj[i]);\n }\n return out;\n}\n\nexport function parseIntVec>(\n out: U,\n obj: any,\n) {\n const length = out.length;\n if (!Array.isArray(obj) || obj.length !== length) {\n throw new Error(\"Incompatible sizes.\");\n }\n\n for (let i = 0; i < length; ++i) {\n const val = parseInt(obj[i], undefined);\n if (!Number.isInteger(val)) {\n throw new Error(\"Non-integer value.\");\n }\n }\n\n for (let i = 0; i < length; ++i) {\n out[i] = parseInt(obj[i], undefined);\n }\n return out;\n}\n\n/**\n * Returns a JSON representation of x, with object keys sorted to ensure a\n * consistent result.\n */\nexport function stableStringify(x: any) {\n if (typeof x === \"object\") {\n if (x === null) {\n return \"null\";\n }\n if (Array.isArray(x)) {\n let s = \"[\";\n const size = x.length;\n let i = 0;\n if (i < size) {\n s += stableStringify(x[i]);\n while (++i < size) {\n s += \",\";\n s += stableStringify(x[i]);\n }\n }\n s += \"]\";\n return s;\n }\n let s = \"{\";\n const keys = Object.keys(x).sort();\n let i = 0;\n const size = keys.length;\n if (i < size) {\n let key = keys[i];\n s += JSON.stringify(key);\n s += \":\";\n s += stableStringify(x[key]);\n while (++i < size) {\n s += \",\";\n key = keys[i];\n s += JSON.stringify(key);\n s += \":\";\n s += stableStringify(x[key]);\n }\n }\n s += \"}\";\n return s;\n }\n return JSON.stringify(x);\n}\n\nfunction swapQuotes(x: string) {\n return x.replace(/['\"]/g, (s) => {\n return s === '\"' ? \"'\" : '\"';\n });\n}\n\nexport function urlSafeStringifyString(x: string) {\n return swapQuotes(JSON.stringify(swapQuotes(x)));\n}\n\nconst URL_SAFE_COMMA = \"_\";\n\nexport function urlSafeStringify(x: any): string {\n if (typeof x === \"object\") {\n if (x === null) {\n return \"null\";\n }\n const toJSON = x.toJSON;\n if (typeof toJSON === \"function\") {\n return urlSafeStringify(toJSON.call(x));\n }\n if (Array.isArray(x)) {\n let s = \"[\";\n const size = x.length;\n let i = 0;\n if (i < size) {\n s += urlSafeStringify(x[i]);\n while (++i < size) {\n s += URL_SAFE_COMMA;\n s += urlSafeStringify(x[i]);\n }\n }\n s += \"]\";\n return s;\n }\n let s = \"{\";\n const keys = Object.keys(x);\n let first = true;\n for (const key of keys) {\n const value = x[key];\n if (value === undefined) {\n continue;\n }\n const valueString = urlSafeStringify(value);\n if (!valueString) {\n continue;\n }\n if (!first) {\n s += URL_SAFE_COMMA;\n } else {\n first = false;\n }\n s += urlSafeStringifyString(key);\n s += \":\";\n s += valueString;\n }\n s += \"}\";\n return s;\n }\n if (typeof x === \"string\") {\n return urlSafeStringifyString(x);\n }\n return JSON.stringify(x);\n}\n\nconst SINGLE_QUOTE_STRING_PATTERN = /('(?:[^'\\\\]|(?:\\\\.))*')/;\nconst DOUBLE_QUOTE_STRING_PATTERN = /(\"(?:[^\"\\\\]|(?:\\\\.))*\")/;\nconst SINGLE_OR_DOUBLE_QUOTE_STRING_PATTERN = new RegExp(\n `${SINGLE_QUOTE_STRING_PATTERN.source}|${DOUBLE_QUOTE_STRING_PATTERN.source}`,\n);\nconst DOUBLE_OR_SINGLE_QUOTE_STRING_PATTERN = new RegExp(\n `${DOUBLE_QUOTE_STRING_PATTERN.source}|${SINGLE_QUOTE_STRING_PATTERN.source}`,\n);\n\nconst DOUBLE_QUOTE_PATTERN = /^((?:[^\"'\\\\]|(?:\\\\[^']))*)(\"|\\\\')/;\nconst SINGLE_QUOTE_PATTERN = /^((?:[^\"'\\\\]|(?:\\\\.))*)'/;\n\nfunction convertStringLiteral(\n x: string,\n quoteInitial: string,\n quoteReplace: string,\n quoteSearch: RegExp,\n) {\n if (\n x.length >= 2 &&\n x.charAt(0) === quoteInitial &&\n x.charAt(x.length - 1) === quoteInitial\n ) {\n let inner = x.substr(1, x.length - 2);\n let s = quoteReplace;\n while (inner.length > 0) {\n const m = inner.match(quoteSearch);\n if (m === null) {\n s += inner;\n break;\n }\n s += m[1];\n if (m[2] === quoteReplace) {\n // We received a single unescaped quoteReplace character.\n s += \"\\\\\";\n s += quoteReplace;\n } else {\n // We received \"\\\\\" + quoteInitial. We need to remove the escaping.\n s += quoteInitial;\n }\n inner = inner.substr(m.index! + m[0].length);\n }\n s += quoteReplace;\n return s;\n }\n return x;\n}\n\n/**\n * Converts a string literal delimited by either single or double quotes into a string literal\n * delimited by double quotes.\n */\nexport function normalizeStringLiteral(x: string) {\n return convertStringLiteral(x, \"'\", '\"', DOUBLE_QUOTE_PATTERN);\n}\n\n// quoteChar: des\nfunction convertJsonHelper(\n x: string,\n desiredCommaChar: string,\n desiredQuoteChar: string,\n) {\n const commaSearch = /[&_,]/g;\n let quoteInitial: string;\n let quoteSearch: RegExp;\n let stringLiteralPattern: RegExp;\n if (desiredQuoteChar === '\"') {\n quoteInitial = \"'\";\n quoteSearch = DOUBLE_QUOTE_PATTERN;\n stringLiteralPattern = SINGLE_OR_DOUBLE_QUOTE_STRING_PATTERN;\n } else {\n quoteInitial = '\"';\n quoteSearch = SINGLE_QUOTE_PATTERN;\n stringLiteralPattern = DOUBLE_OR_SINGLE_QUOTE_STRING_PATTERN;\n }\n let s = \"\";\n while (x.length > 0) {\n const m = x.match(stringLiteralPattern);\n let before: string;\n let replacement: string;\n if (m === null) {\n before = x;\n x = \"\";\n replacement = \"\";\n } else {\n before = x.substr(0, m.index);\n x = x.substr(m.index! + m[0].length);\n const originalString = m[1];\n if (originalString !== undefined) {\n replacement = convertStringLiteral(\n originalString,\n quoteInitial,\n desiredQuoteChar,\n quoteSearch,\n );\n } else {\n replacement = m[2];\n }\n }\n s += before.replace(commaSearch, desiredCommaChar);\n s += replacement;\n }\n return s;\n}\n\nexport function urlSafeToJSON(x: string) {\n return convertJsonHelper(x, \",\", '\"');\n}\n\nexport function jsonToUrlSafe(x: string) {\n return convertJsonHelper(x, \"_\", \"'\");\n}\n\nexport function urlSafeParse(x: string) {\n return JSON.parse(urlSafeToJSON(x));\n}\n\n// Converts a string containing a Python literal into a string containing an equivalent JSON\n// literal.\nexport function pythonLiteralToJSON(x: string) {\n let s = \"\";\n while (x.length > 0) {\n const m = x.match(SINGLE_OR_DOUBLE_QUOTE_STRING_PATTERN);\n let before: string;\n let replacement: string;\n if (m === null) {\n before = x;\n x = \"\";\n replacement = \"\";\n } else {\n before = x.substr(0, m.index);\n x = x.substr(m.index! + m[0].length);\n const singleQuoteString = m[1];\n if (singleQuoteString !== undefined) {\n replacement = normalizeStringLiteral(singleQuoteString);\n } else {\n replacement = m[2];\n }\n }\n s += before\n .replace(/\\(/g, \"[\")\n .replace(/\\)/g, \"]\")\n .replace(\"True\", \"true\")\n .replace(\"False\", \"false\")\n .replace(/,\\s*([}\\]])/g, \"$1\");\n s += replacement;\n }\n return s;\n}\n\n// Converts a string containing a Python literal into an equivalent JavaScript value.\nexport function pythonLiteralParse(x: string) {\n return JSON.parse(pythonLiteralToJSON(x));\n}\n\nexport function expectArray(x: unknown, length?: number): any[] {\n if (!Array.isArray(x)) {\n throw new Error(`Expected array, but received: ${JSON.stringify(x)}.`);\n }\n if (length !== undefined && x.length !== length) {\n throw new Error(\n `Expected array of length ${length}, but received: ${JSON.stringify(x)}.`,\n );\n }\n return x;\n}\n\n// Checks that `x' is an array, maps each element by parseElement.\nexport function parseArray(\n x: any,\n parseElement: (x: any, index: number) => T,\n): T[] {\n if (!Array.isArray(x)) {\n throw new Error(`Expected array, but received: ${JSON.stringify(x)}.`);\n }\n return (x).map(parseElement);\n}\n\nexport function parseFixedLengthArray>(\n out: U,\n obj: any,\n parseElement: (x: any, index: number) => T,\n): U {\n const length = out.length;\n if (!Array.isArray(obj) || obj.length !== length) {\n throw new Error(\n `Expected length ${length} array, but received: ${JSON.stringify(obj)}.`,\n );\n }\n for (let i = 0; i < length; ++i) {\n out[i] = parseElement(obj[i], i);\n }\n return out;\n}\n\nexport function verifyObject(obj: any) {\n if (typeof obj !== \"object\" || obj == null || Array.isArray(obj)) {\n throw new Error(\n `Expected JSON object, but received: ${JSON.stringify(obj)}.`,\n );\n }\n return obj;\n}\n\nexport function verifyInt(obj: any) {\n const result = parseInt(obj, 10);\n if (!Number.isInteger(result)) {\n throw new Error(`Expected integer, but received: ${JSON.stringify(obj)}.`);\n }\n return result;\n}\n\nexport function verifyPositiveInt(obj: any) {\n const result = verifyInt(obj);\n if (result <= 0) {\n throw new Error(`Expected positive integer, but received: ${result}.`);\n }\n return result;\n}\n\nexport function verifyNonnegativeInt(obj: any) {\n const result = verifyInt(obj);\n if (result < 0) {\n throw new Error(`Expected non-negative integer, but received: ${result}.`);\n }\n return result;\n}\n\nexport function verifyMapKey(obj: any, map: Map) {\n const result = map.get(obj);\n if (result === undefined) {\n throw new Error(\n `Expected one of ${JSON.stringify(Array.from(map.keys()))}, ` +\n `but received: ${JSON.stringify(obj)}.`,\n );\n }\n return result;\n}\n\nexport function verifyString(obj: any) {\n if (typeof obj !== \"string\") {\n throw new Error(`Expected string, but received: ${JSON.stringify(obj)}.`);\n }\n return obj;\n}\n\nexport function verifyOptionalString(obj: any): string | undefined {\n if (obj === undefined) {\n return undefined;\n }\n return verifyString(obj);\n}\n\nexport function verifyOptionalInt(obj: any): number | undefined {\n if (obj === undefined) {\n return undefined;\n }\n return verifyInt(obj);\n}\n\nexport function verifyOptionalBoolean(obj: any): boolean | undefined {\n if (obj === undefined) {\n return undefined;\n }\n if (typeof obj === \"boolean\") {\n return obj;\n }\n if (obj === \"true\") {\n return true;\n }\n if (obj === \"false\") {\n return false;\n }\n throw new Error(\n `Expected string or boolean but received: ${JSON.stringify(obj)}`,\n );\n}\n\nexport function valueOr(value: T | undefined, defaultValue: T) {\n return value === undefined ? defaultValue : value;\n}\n\nexport function verifyObjectProperty(\n obj: any,\n propertyName: string,\n validator: (value: any) => T,\n): T {\n const value = Object.prototype.hasOwnProperty.call(obj, propertyName)\n ? obj[propertyName]\n : undefined;\n try {\n return validator(value);\n } catch (parseError) {\n throw new Error(\n `Error parsing ${JSON.stringify(propertyName)} property: ${\n parseError.message\n }`,\n );\n }\n}\n\nexport function verifyOptionalObjectProperty(\n obj: any,\n propertyName: string,\n validator: (value: any) => T,\n): T | undefined;\n\nexport function verifyOptionalObjectProperty(\n obj: any,\n propertyName: string,\n validator: (value: any) => T,\n defaultValue: T,\n): T;\n\nexport function verifyOptionalObjectProperty(\n obj: any,\n propertyName: string,\n validator: (value: any) => T,\n defaultValue?: any,\n) {\n return verifyObjectProperty(obj, propertyName, (x) =>\n x === undefined ? defaultValue : validator(x),\n );\n}\n\nexport function verifyObjectAsMap(\n obj: any,\n validator: (value: any) => T,\n): Map {\n verifyObject(obj);\n const map = new Map();\n for (const key of Object.keys(obj)) {\n try {\n map.set(key, validator(obj[key]));\n } catch (parseError) {\n throw new Error(\n `Error parsing value associated with key ${JSON.stringify(key)}: ${\n parseError.message\n }`,\n );\n }\n }\n return map;\n}\n\nexport function verifyFloat01(obj: any): number {\n if (typeof obj !== \"number\" || !Number.isFinite(obj) || obj < 0 || obj > 1) {\n throw new Error(\n `Expected floating point number in [0,1], but received: ${JSON.stringify(\n obj,\n )}.`,\n );\n }\n return obj;\n}\n\n/**\n * The query string parameters may either be specified in the usual\n * 'name=value&otherName=otherValue' form or as (optionally urlSafe) JSON: '{\"name\":\"value\"}`.\n */\nexport function parseQueryStringParameters(queryString: string) {\n if (queryString === \"\") {\n return {};\n }\n if (queryString.startsWith(\"{\")) {\n return urlSafeParse(queryString);\n }\n const result: any = {};\n const parts = queryString.split(/[&;]/);\n for (const part of parts) {\n const m = part.match(/^([^=&;]+)=([^&;]*)$/);\n if (m === null) {\n throw new Error(`Invalid query string part: ${JSON.stringify(part)}.`);\n }\n result[m[1]] = decodeURIComponent(m[2]);\n }\n return result;\n}\n\nexport function unparseQueryStringParameters(parameters: any) {\n if (parameters === undefined) return \"\";\n const keys = Object.keys(parameters);\n if (keys.length === 0) return \"\";\n if (keys.some((key) => typeof parameters[key] !== \"string\")) {\n return JSON.stringify(parameters);\n }\n return keys\n .map(\n (key) =>\n `${encodeURIComponent(key)}=${encodeURIComponent(parameters[key])}`,\n )\n .join(\"&\");\n}\n\n/**\n * Verifies that `obj' is a string that, when converted to uppercase, matches a string property of\n * `enumType`.\n *\n * @returns The corresponding numerical value.\n */\nexport function verifyEnumString(\n obj: any,\n enumType: { [x: string]: T | string },\n pattern: RegExp = /^[a-zA-Z]/,\n): T {\n if (typeof obj === \"string\" && obj.match(pattern) !== null) {\n const objUpperCase = obj.toUpperCase();\n if (Object.prototype.hasOwnProperty.call(enumType, objUpperCase)) {\n return enumType[objUpperCase] as T;\n }\n }\n throw new Error(`Invalid enum value: ${JSON.stringify(obj)}.`);\n}\n\nexport function verify3dVec(obj: any) {\n return parseFixedLengthArray(vec3.create(), obj, verifyFiniteFloat);\n}\n\nexport function verify3dScale(obj: any) {\n return parseFixedLengthArray(vec3.create(), obj, verifyFinitePositiveFloat);\n}\n\nexport function verify3dDimensions(obj: any) {\n return parseFixedLengthArray(vec3.create(), obj, verifyPositiveInt);\n}\n\nexport function verifyStringArray(a: any) {\n if (!Array.isArray(a)) {\n throw new Error(`Expected array, received: ${JSON.stringify(a)}.`);\n }\n for (const x of a) {\n if (typeof x !== \"string\") {\n throw new Error(`Expected string, received: ${JSON.stringify(x)}.`);\n }\n }\n return a;\n}\n\nexport function verifyIntegerArray(a: unknown) {\n if (!Array.isArray(a)) {\n throw new Error(`Expected array, received: ${JSON.stringify(a)}.`);\n }\n for (const x of a) {\n if (!Number.isInteger(x)) {\n throw new Error(`Expected integer, received: ${JSON.stringify(x)}.`);\n }\n }\n return a;\n}\n\nexport function verifyFloatArray(a: unknown) {\n if (!Array.isArray(a)) {\n throw new Error(`Expected array, received: ${JSON.stringify(a)}.`);\n }\n for (const x of a) {\n verifyFloat(x);\n }\n return a;\n}\n\nexport function verifyBoolean(x: any) {\n if (typeof x !== \"boolean\") {\n throw new Error(`Expected boolean, received: ${JSON.stringify(x)}`);\n }\n return x;\n}\n\n// If `x` is an empty object/array/string, returns undefined. Otherwise returns `x`.\nexport function emptyToUndefined(x: any) {\n for (const _ in x) {\n return x;\n }\n return undefined;\n}\n\nexport function verifyConstant(actual: unknown, expected: T) {\n if (actual !== expected) {\n throw new Error(\n `Expected ${JSON.stringify(expected)}, but received: ${JSON.stringify(\n actual,\n )}`,\n );\n }\n return expected;\n}\n\nexport function verifyOptionalFixedLengthArrayOfStringOrNull(\n obj: unknown,\n rank: number,\n) {\n if (obj === undefined) {\n const array = new Array(rank);\n array.fill(null);\n return array;\n }\n return parseFixedLengthArray(new Array(rank), obj, (value) => {\n if (value !== null && typeof value !== \"string\") {\n throw new Error(\n `Expected string or null, but received: ${JSON.stringify(name)}`,\n );\n }\n return value;\n });\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { TypedArray } from \"#src/util/array.js\";\n\n/**\n * Sets the `m * k` matrix `c` to the product of `m * n` matrix `a` and `n * k` matrix `b`.\n *\n * `a`, `b` and `c` are column-major with column strides of `lda`, `ldb`, and `ldc`, respectively.\n * `c` must not overlap `a` or `b`.\n */\nexport function multiply(\n c: T,\n ldc: number,\n a: T,\n lda: number,\n b: T,\n ldb: number,\n m: number,\n n: number,\n k: number,\n): T {\n for (let mIndex = 0; mIndex < m; ++mIndex) {\n for (let kIndex = 0; kIndex < k; ++kIndex) {\n let sum = 0;\n for (let nIndex = 0; nIndex < n; ++nIndex) {\n sum += a[mIndex + lda * nIndex] * b[nIndex + ldb * kIndex];\n }\n c[mIndex + ldc * kIndex] = sum;\n }\n }\n return c;\n}\n\nexport function identity(\n a: T,\n lda: number,\n n: number,\n): T {\n for (let i = 0; i < n; ++i) {\n const start = lda * i;\n a.fill(0, start, start + n);\n a[start + i] = 1;\n }\n return a;\n}\n\nexport function createIdentity(\n c: { new (n: number): T },\n rows: number,\n cols: number = rows,\n): T {\n return identity(new c(rows * cols), rows, Math.min(rows, cols));\n}\n\nexport function createHomogeneousScaleMatrix(\n c: { new (length: number): T },\n scales: ArrayLike,\n square = true,\n): T {\n const rank = scales.length;\n const stride = square ? rank + 1 : rank;\n const m = new c(stride * (rank + 1));\n if (square) {\n m[m.length - 1] = 1;\n }\n for (let i = 0; i < rank; ++i) {\n m[(stride + 1) * i] = scales[i];\n }\n return m;\n}\n\nexport function createHomogeneousTranslationMatrix(\n c: { new (length: number): T },\n translation: ArrayLike,\n square = true,\n): T {\n const rank = translation.length;\n const stride = square ? rank + 1 : rank;\n const m = createIdentity(c, stride, rank + 1);\n for (let i = 0; i < rank; ++i) {\n m[stride * rank + i] = translation[i];\n }\n return m;\n}\n\nexport function isIdentity(a: T, lda: number, n: number) {\n for (let i = 0; i < n; ++i) {\n for (let j = 0; j < n; ++j) {\n if (a[i * lda + j] !== (i === j ? 1 : 0)) return false;\n }\n }\n return true;\n}\n\nexport function copy(\n b: T,\n ldb: number,\n a: T,\n lda: number,\n m: number,\n n: number,\n): T {\n for (let col = 0; col < n; ++col) {\n const aOff = col * lda;\n const bOff = col * ldb;\n for (let row = 0; row < m; ++row) {\n b[bOff + row] = a[aOff + row];\n }\n }\n return b;\n}\n\nexport function extendHomogeneousTransform(\n b: T,\n bRank: number,\n a: T,\n aRank: number,\n) {\n copy(b, bRank + 1, a, aRank + 1, aRank, aRank);\n for (let i = 0; i < aRank; ++i) {\n b[(bRank + 1) * bRank + i] = a[(aRank + 1) * aRank + i];\n }\n b[b.length - 1] = 1;\n for (let i = aRank; i < bRank; ++i) {\n b[(bRank + 1) * i + i] = 1;\n }\n return b;\n}\n\nlet pivots: Uint32Array | undefined;\n\n/**\n * Computes the inverse of a square matrix in place, and returns the determinant.\n */\nexport function inverseInplace(\n a: T,\n lda: number,\n n: number,\n): number {\n let determinant = 1;\n // Use Gauss-Jordan elimination with partial pivoting to compute inverse.\n if (pivots === undefined || pivots.length < n) {\n pivots = new Uint32Array(n);\n }\n for (let i = 0; i < n; ++i) {\n pivots[i] = i;\n }\n for (let k = 0; k < n; ++k) {\n const kColOff = lda * k;\n // Find best pivot (row >= `k` with maximum-magnitude element in column `k`).\n let pivotRow = k;\n {\n let bestPivot = Math.abs(a[kColOff + k]);\n for (let row = k + 1; row < n; ++row) {\n const mag = Math.abs(a[kColOff + row]);\n if (mag > bestPivot) {\n bestPivot = mag;\n pivotRow = row;\n }\n }\n }\n // Swap rows `k` and `pivotRow`.\n if (k !== pivotRow) {\n determinant *= -1;\n for (let col = 0; col < n; ++col) {\n const off = lda * col;\n const temp = a[off + k];\n a[off + k] = a[off + pivotRow];\n a[off + pivotRow] = temp;\n }\n\n // Swap `pivots[k]` with `pivots[pivotRow]`.\n {\n const tempPivot = pivots[k];\n pivots[k] = pivots[pivotRow];\n pivots[pivotRow] = tempPivot;\n }\n }\n // Eliminate.\n const pivotValue = a[kColOff + k];\n const pivotInv = 1.0 / pivotValue;\n\n // Divide row `k` by the pivot element.\n determinant *= pivotValue;\n for (let j = 0; j < n; ++j) {\n a[lda * j + k] *= pivotInv;\n }\n // Convert `a(k, k)` to contain the inverse element.\n a[kColOff + k] = pivotInv;\n\n // Subtract a suitable multiple of row `k` from all other rows to ensure column `k` becomes `0`.\n for (let row = 0; row < n; ++row) {\n if (row === k) continue;\n const factor = -a[lda * k + row];\n for (let j = 0; j < n; ++j) {\n const jColOff = lda * j;\n a[jColOff + row] += factor * a[jColOff + k];\n }\n // Convert element in column `k` to contain the inverse element.\n a[lda * k + row] = factor * pivotInv;\n }\n }\n // Permute columns back to correct order.\n for (let col = 0; col < n; ++col) {\n let targetCol = pivots[col];\n while (targetCol !== col) {\n const colOff = lda * col;\n const targetColOff = lda * targetCol;\n for (let i = 0; i < n; ++i) {\n const off1 = colOff + i;\n const off2 = targetColOff + i;\n const temp = a[off1];\n a[off1] = a[off2];\n a[off2] = temp;\n }\n const temp = (pivots[col] = pivots[targetCol]);\n pivots[targetCol] = targetCol;\n targetCol = temp;\n }\n }\n return determinant;\n}\n\n/**\n * Computes the inverse and returns the determinant.\n */\nexport function inverse(\n b: T,\n ldb: number,\n a: T,\n lda: number,\n n: number,\n): number {\n copy(b, ldb, a, lda, n, n);\n return inverseInplace(b, ldb, n);\n}\n\nexport function equal(\n a: T,\n lda: number,\n b: T,\n ldb: number,\n m: number,\n n: number,\n) {\n for (let j = 0; j < n; ++j) {\n const offA = lda * j;\n const offB = ldb * j;\n for (let i = 0; i < m; ++i) {\n if (a[offA + i] !== b[offB + i]) return false;\n }\n }\n return true;\n}\n\nexport function transpose(\n b: T,\n ldb: number,\n a: T,\n lda: number,\n m: number,\n n: number,\n) {\n for (let i = 0; i < m; ++i) {\n for (let j = 0; j < n; ++j) {\n b[j + i * ldb] = a[i + j * lda];\n }\n }\n return b;\n}\n\nexport function transformPoint<\n Out extends TypedArray,\n Matrix extends TypedArray,\n Vector extends TypedArray,\n>(out: Out, mat: Matrix, matrixStride: number, vec: Vector, rank: number): Out {\n for (let i = 0; i < rank; ++i) {\n let sum = mat[matrixStride * rank + i];\n for (let j = 0; j < rank; ++j) {\n sum += mat[matrixStride * j + i] * vec[j];\n }\n out[i] = sum;\n }\n return out;\n}\n\nexport function transformVector<\n Out extends TypedArray,\n Matrix extends TypedArray,\n Vector extends TypedArray,\n>(out: Out, mat: Matrix, matrixStride: number, vec: Vector, rank: number): Out {\n for (let i = 0; i < rank; ++i) {\n let sum = 0;\n for (let j = 0; j < rank; ++j) {\n sum += mat[matrixStride * j + i] * vec[j];\n }\n out[i] = sum;\n }\n return out;\n}\n\nexport function permuteRows<\n Output extends TypedArray,\n Input extends TypedArray,\n>(\n output: Output,\n outputStride: number,\n input: Input,\n inputStride: number,\n outputToInputRow: ReadonlyArray,\n cols: number,\n) {\n const rows = outputToInputRow.length;\n for (let outRow = 0; outRow < rows; ++outRow) {\n const inRow = outputToInputRow[outRow];\n for (let col = 0; col < cols; ++col) {\n output[col * outputStride + outRow] = input[col * inputStride + inRow];\n }\n }\n return output;\n}\n\nexport function permuteCols<\n Output extends TypedArray,\n Input extends TypedArray,\n>(\n output: Output,\n outputStride: number,\n input: Input,\n inputStride: number,\n outputToInputCol: ReadonlyArray,\n rows: number,\n) {\n const cols = outputToInputCol.length;\n for (let outCol = 0; outCol < cols; ++outCol) {\n const inCol = outputToInputCol[outCol];\n for (let row = 0; row < rows; ++row) {\n output[outCol * outputStride + row] = input[inCol * inputStride + row];\n }\n }\n return output;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Simple signal dispatch mechanism.\n */\n\n/**\n * This class provides a simple signal dispatch mechanism. Handlers can be added, and then the\n * `dispatch` method calls all of them.\n *\n * If specified, Callable should be an interface containing only a callable signature returning\n * void. Due to limitations in TypeScript, any interface containing a callable signature will be\n * accepted by the compiler, but the resultant signature of `dispatch` will not be correct.\n */\nexport class Signal void> {\n private handlers = new Set();\n\n /**\n * Count of number of times this signal has been dispatched. This is incremented each time\n * `dispatch` is called prior to invoking the handlers.\n */\n count = 0;\n\n constructor() {\n const obj = this;\n this.dispatch = (function (this: any) {\n ++obj.count;\n obj.handlers.forEach((handler) => {\n // eslint-disable-next-line prefer-rest-params\n handler.apply(this, arguments);\n });\n });\n }\n\n /**\n * Add a handler function. If `dispatch` is currently be called, then the new handler will be\n * called before `dispatch` returns.\n *\n * @param handler The handler function to add.\n *\n * @return A function that unregisters the handler.\n */\n add(handler: Callable): () => boolean {\n this.handlers.add(handler);\n return () => {\n return this.remove(handler);\n };\n }\n\n /**\n * Remove a handler function. If `dispatch` is currently be called and the new handler has not\n * yet been called, then it will not be called.\n *\n * @param handler Handler to remove.\n * @return `true` if the handler was present, `false` otherwise.\n */\n remove(handler: Callable): boolean {\n return this.handlers.delete(handler);\n }\n\n /**\n * Invokes each handler function with the same parameters (including `this`) with which it is\n * called. Handlers are invoked in the order in which they were added.\n */\n dispatch: Callable;\n\n /**\n * Disposes of resources. No methods, including `dispatch`, may be invoked afterwards.\n */\n dispose() {\n this.handlers = undefined;\n }\n}\n\nexport function observeSignal(\n callback: () => void,\n ...signals: {\n add(callback: () => void): void;\n remove(callback: () => void): void;\n }[]\n) {\n callback();\n for (let i = 0, count = signals.length; i < count; ++i) {\n signals[i].add(callback);\n }\n return () => {\n for (let i = 0, count = signals.length; i < count; ++i) {\n signals[i].remove(callback);\n }\n };\n}\n\n/**\n * Simple specialization of Signal for the common case of a nullary handler signature.\n */\nexport class NullarySignal extends Signal<() => void> {}\n\n/**\n * Interface for a signal excluding the dispatch method.\n *\n * Unlike Signal, this interface is covariant in the type of Callable.\n */\nexport interface ReadonlySignal {\n readonly count: number;\n add(handler: Callable): () => void;\n remove(handler: Callable): boolean;\n}\n\nexport type NullaryReadonlySignal = ReadonlySignal<() => void>;\n\nexport const neverSignal: NullaryReadonlySignal = {\n count: 0,\n add(_handler: any) {\n return () => {};\n },\n remove(_handler: any) {\n return false;\n },\n};\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport function hexEncodeByte(x: number) {\n return (\"0\" + x.toString(16)).slice(-2);\n}\n\nexport function hexEncode(arr: Uint8Array) {\n return Array.prototype.map.call(arr, hexEncodeByte).join(\"\");\n}\n\nexport function hexDecode(x: string) {\n if (!/^(?:[0-9a-fA-F]{2})*$/.test(x)) {\n throw new Error(\"Invalid hex-encoded string\");\n }\n const length = x.length / 2;\n const result = new Uint8Array(length);\n for (let i = 0; i < length; ++i) {\n result[i] = parseInt(x.substr(i * 2, 2), 16);\n }\n return result;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Facilities for converting between strings and RGB/RGBA colors.\n */\n\nimport { WatchableValue } from \"#src/trackable_value.js\";\nimport { float32ToString } from \"#src/util/float32_to_string.js\";\nimport { vec3, vec4 } from \"#src/util/geom.js\";\nimport { hexEncodeByte } from \"#src/util/hex.js\";\n\n/**\n * Parse the serialization of a color.\n *\n * This is based on the definition here:\n * https://html.spec.whatwg.org/multipage/canvas.html#serialisation-of-a-color\n */\nexport function parseColorSerialization(x: string) {\n const rgbaPattern =\n /^rgba\\(([0-9]+), ([0-9]+), ([0-9]+), (0(?:\\.[0-9]+)?)\\)$/;\n {\n const m = x.match(rgbaPattern);\n if (m !== null) {\n return [\n parseInt(m[1], 10),\n parseInt(m[2], 10),\n parseInt(m[3], 10),\n parseFloat(m[4]),\n ];\n }\n }\n const hexPattern = /^#([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})$/;\n {\n const m = x.match(hexPattern);\n if (m !== null) {\n return [parseInt(m[1], 16), parseInt(m[2], 16), parseInt(m[3], 16), 1.0];\n }\n }\n throw new Error(`Invalid serialized color: ${JSON.stringify(x)}.`);\n}\n\nexport function parseRGBAColorSpecification(x: any) {\n try {\n if (typeof x !== \"string\") {\n throw new Error(`Expected string, but received ${JSON.stringify(x)}.`);\n }\n const context = document.createElement(\"canvas\").getContext(\"2d\")!;\n context.fillStyle = x;\n const result = parseColorSerialization(context.fillStyle);\n return vec4.fromValues(\n result[0] / 255,\n result[1] / 255,\n result[2] / 255,\n result[3],\n );\n } catch (parseError) {\n throw new Error(\n `Failed to parse color specification: ${parseError.message}`,\n );\n }\n}\n\nexport function parseRGBColorSpecification(x: any) {\n const result = parseRGBAColorSpecification(x);\n return result.subarray(0, 3);\n}\n\n/**\n * Returns an integer formed by concatenating the channels of the input color vector.\n * Each channel is clamped to the range [0.0, 1.0] before being converted to 8 bits.\n * An RGB color is packed into 24 bits, and a RGBA into 32 bits.\n */\nexport function packColor(x: vec3 | vec4): number {\n const size = x[3] === undefined ? 3 : 4;\n let result = 0;\n for (let i = 0; i < size; i++) {\n // The \">>> 0\" ensures an unsigned value.\n result =\n ((result << 8) >>> 0) +\n Math.min(255, Math.max(0, Math.round(x[size - 1 - i] * 255)));\n }\n return result;\n}\n\nexport function unpackRGB(value: number) {\n return vec3.fromValues(\n ((value >>> 0) & 0xff) / 255,\n ((value >>> 8) & 0xff) / 255,\n ((value >>> 16) & 0xff) / 255,\n );\n}\n\nexport function unpackRGBA(value: number) {\n return vec4.fromValues(\n ((value >>> 0) & 0xff) / 255,\n ((value >>> 8) & 0xff) / 255,\n ((value >>> 16) & 0xff) / 255,\n ((value >>> 24) & 0xff) / 255,\n );\n}\n\nexport function serializeColor(x: vec3 | vec4) {\n if (x[3] === undefined || x[3] === 1) {\n let result = \"#\";\n for (let i = 0; i < 3; ++i) {\n result += hexEncodeByte(\n Math.min(255, Math.max(0, Math.round(x[i] * 255))),\n );\n }\n return result;\n }\n let result = \"rgba(\";\n for (let i = 0; i < 3; ++i) {\n if (i !== 0) {\n result += \", \";\n }\n result += Math.min(255, Math.max(0, Math.round(x[i] * 255)));\n }\n result += `, ${float32ToString(x[3])})`;\n return result;\n}\n\n// Converts an sRGB color component to the gamma-expanded (\"linear\") value.\nexport function srgbGammaExpand(value: number) {\n return value <= 0.03928 ? value / 12.92 : ((value + 0.055) / 1.055) ** 2.4;\n}\n\n// Computes the relative luminance according to Web Content Accessibility Guidelines (WCAG) 2.0\n//\n// https://www.w3.org/TR/WCAG20/#relativeluminancedef\n//\n// @param color sRGB color\nexport function getRelativeLuminance(color: vec3 | vec4) {\n const [r, g, b] = color;\n return (\n 0.2126 * srgbGammaExpand(r) +\n 0.7152 * srgbGammaExpand(g) +\n 0.0722 * srgbGammaExpand(b)\n );\n}\n\n// Determines whether a white background would provide higher contrast than a black background for\n// the given foreground color.\n//\n// This is determined according to the Web Content Accessibility Guidelines (WCAG) 2.0:\n// https://www.w3.org/TR/WCAG20/#contrast-ratiodef\n//\n// https://stackoverflow.com/a/3943023\nexport function useWhiteBackground(foregroundColor: vec3 | vec4) {\n return getRelativeLuminance(foregroundColor) <= 0.179;\n}\n\nexport class TrackableRGB extends WatchableValue {\n constructor(public defaultValue: vec3) {\n super(vec3.clone(defaultValue));\n }\n toString() {\n return serializeColor(this.value);\n }\n toJSON() {\n if (vec3.equals(this.value, this.defaultValue)) {\n return undefined;\n }\n return serializeColor(this.value);\n }\n reset() {\n this.value = vec3.clone(this.defaultValue);\n }\n restoreState(x: any) {\n if (x === undefined) {\n this.reset();\n return;\n }\n const { value } = this;\n const newValue = parseRGBColorSpecification(x);\n if (!vec3.equals(value, newValue)) {\n this.value = newValue;\n }\n }\n}\n\nexport class TrackableOptionalRGB extends WatchableValue {\n constructor() {\n super(undefined);\n }\n toJSON() {\n const { value } = this;\n if (value === undefined) return undefined;\n return serializeColor(value);\n }\n reset() {\n this.value = undefined;\n }\n restoreState(x: any) {\n if (x === undefined) {\n this.reset();\n return;\n }\n const { value } = this;\n const newValue = parseRGBColorSpecification(x);\n if (value === undefined || !vec3.equals(value, newValue)) {\n this.value = newValue;\n }\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { TypedArrayConstructor } from \"#src/util/array.js\";\n\n/**\n * If this is updated, DATA_TYPE_BYTES must also be updated.\n */\nexport enum DataType {\n UINT8 = 0,\n INT8 = 1,\n UINT16 = 2,\n INT16 = 3,\n UINT32 = 4,\n INT32 = 5,\n UINT64 = 6,\n FLOAT32 = 7,\n}\n\nexport const DATA_TYPE_SIGNED: Record = {\n [DataType.UINT8]: false,\n [DataType.INT8]: true,\n [DataType.UINT16]: false,\n [DataType.INT16]: true,\n [DataType.UINT32]: false,\n [DataType.INT32]: true,\n [DataType.UINT64]: false,\n [DataType.FLOAT32]: undefined,\n};\n\nexport const DATA_TYPE_BYTES: Record = {\n [DataType.UINT8]: 1,\n [DataType.INT8]: 1,\n [DataType.UINT16]: 2,\n [DataType.INT16]: 2,\n [DataType.UINT32]: 4,\n [DataType.INT32]: 4,\n [DataType.UINT64]: 8,\n [DataType.FLOAT32]: 4,\n};\n\nexport const DATA_TYPE_ARRAY_CONSTRUCTOR: Record<\n DataType,\n TypedArrayConstructor\n> = {\n [DataType.UINT8]: Uint8Array,\n [DataType.INT8]: Int8Array,\n [DataType.UINT16]: Uint16Array,\n [DataType.INT16]: Int16Array,\n [DataType.UINT32]: Uint32Array,\n [DataType.INT32]: Int32Array,\n [DataType.UINT64]: Uint32Array,\n [DataType.FLOAT32]: Float32Array,\n};\n\nexport const DATA_TYPE_JAVASCRIPT_ELEMENTS_PER_ARRAY_ELEMENT: Record<\n DataType,\n number\n> = {\n [DataType.UINT8]: 1,\n [DataType.INT8]: 1,\n [DataType.UINT16]: 1,\n [DataType.INT16]: 1,\n [DataType.UINT32]: 1,\n [DataType.INT32]: 1,\n [DataType.UINT64]: 2,\n [DataType.FLOAT32]: 1,\n};\n\nexport function makeDataTypeArrayView(\n dataType: DataType,\n buffer: ArrayBuffer,\n byteOffset = 0,\n byteLength: number = buffer.byteLength,\n): ArrayBufferView {\n const bytesPerElement = DATA_TYPE_BYTES[dataType];\n const javascriptElementsPerArrayElement =\n DATA_TYPE_JAVASCRIPT_ELEMENTS_PER_ARRAY_ELEMENT[dataType];\n return new DATA_TYPE_ARRAY_CONSTRUCTOR[dataType](\n buffer,\n byteOffset,\n (byteLength / bytesPerElement) * javascriptElementsPerArrayElement,\n );\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Facilities for endianness detection and swapping.\n */\n\nexport enum Endianness {\n LITTLE = 0,\n BIG = 1,\n}\n\nexport function determineEndianness() {\n const a = Uint16Array.of(0x1122);\n const b = new Uint8Array(a.buffer);\n return b[0] === 0x11 ? Endianness.BIG : Endianness.LITTLE;\n}\n\n/**\n * The native endianness of the runtime.\n */\nexport const ENDIANNESS = determineEndianness();\n\n/**\n * Swaps the endianness of an array assumed to contain 16-bit values.\n */\nexport function swapEndian16(array: ArrayBufferView) {\n const view = new Uint8Array(array.buffer, array.byteOffset, array.byteLength);\n for (let i = 0, length = view.length; i < length; i += 2) {\n const temp = view[i];\n view[i] = view[i + 1];\n view[i + 1] = temp;\n }\n}\n\n/**\n * Swaps the endianness of an array assumed to contain 32-bit values.\n */\nexport function swapEndian32(array: ArrayBufferView) {\n const view = new Uint8Array(array.buffer, array.byteOffset, array.byteLength);\n for (let i = 0, length = view.length; i < length; i += 4) {\n let temp = view[i];\n view[i] = view[i + 3];\n view[i + 3] = temp;\n temp = view[i + 1];\n view[i + 1] = view[i + 2];\n view[i + 2] = temp;\n }\n}\n\nexport function swapEndian64(array: ArrayBufferView) {\n const view = new Uint8Array(array.buffer, array.byteOffset, array.byteLength);\n for (let i = 0, length = view.length; i < length; i += 8) {\n let temp = view[i];\n view[i] = view[i + 7];\n view[i + 7] = temp;\n temp = view[i + 1];\n view[i + 1] = view[i + 6];\n view[i + 6] = temp;\n temp = view[i + 2];\n view[i + 2] = view[i + 5];\n view[i + 5] = temp;\n temp = view[i + 3];\n view[i + 3] = view[i + 4];\n view[i + 4] = temp;\n }\n}\n\n/**\n * Converts the endianness of an array assumed to contain 16-bit values from source to target.\n *\n * This does nothing if source === target.\n */\nexport function convertEndian16(\n array: ArrayBufferView,\n source: Endianness,\n target: Endianness = ENDIANNESS,\n) {\n if (source !== target) {\n swapEndian16(array);\n }\n}\n\n/**\n * Converts the endianness of an array assumed to contain 32-bit values from source to target.\n *\n * This does nothing if source === target.\n */\nexport function convertEndian32(\n array: ArrayBufferView,\n source: Endianness,\n target: Endianness = ENDIANNESS,\n) {\n if (source !== target) {\n swapEndian32(array);\n }\n}\n\n/**\n * Converts the endianness of an array assumed to contain 64-bit values from source to target.\n *\n * This does nothing if source === target.\n */\nexport function convertEndian64(\n array: ArrayBufferView,\n source: Endianness,\n target: Endianness = ENDIANNESS,\n) {\n if (source !== target) {\n swapEndian64(array);\n }\n}\n\nexport function convertEndian(\n array: ArrayBufferView,\n source: Endianness,\n elementBytes: number,\n target: Endianness = ENDIANNESS,\n) {\n if (source === target || elementBytes === 1) return;\n switch (elementBytes) {\n case 2:\n swapEndian16(array);\n break;\n case 4:\n swapEndian32(array);\n break;\n case 8:\n swapEndian64(array);\n break;\n }\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Endianness, ENDIANNESS } from \"#src/util/endian.js\";\n\nconst denormMin = 2 ** -1074;\n\nconst float64Buf = new Float64Array(1);\nconst uint32Buf = new Uint32Array(float64Buf.buffer);\n\n// The following implementation is derived from:\n// https://github.com/scijs/nextafter/\n//\n// and is subject to the following license:\n//\n// The MIT License (MIT)\n//\n// Copyright (c) 2013 Mikola Lysenko\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n// Like the C standard library `nextafter` function, returns the next representable JavaScript\n// number (float64) after `x` in the direction of `y`. Returns `y` if `x === y`.\nexport function nextAfterFloat64(x: number, y: number) {\n if (Number.isNaN(x) || Number.isNaN(y)) return NaN;\n if (x === y) return y;\n if (x === 0) {\n return y < 0 ? -denormMin : denormMin;\n }\n float64Buf[0] = x;\n const lowIndex = ENDIANNESS === Endianness.LITTLE ? 0 : 1;\n const highIndex = 1 - lowIndex;\n if (y > x === x > 0) {\n if (uint32Buf[lowIndex] === 0xffffffff) {\n uint32Buf[lowIndex] = 0;\n uint32Buf[highIndex] += 1;\n } else {\n uint32Buf[lowIndex] += 1;\n }\n } else {\n if (uint32Buf[lowIndex] === 0) {\n uint32Buf[lowIndex] = 0xffffffff;\n uint32Buf[highIndex] -= 1;\n } else {\n uint32Buf[lowIndex] -= 1;\n }\n }\n return float64Buf[0];\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { DataType } from \"#src/util/data_type.js\";\nimport { nextAfterFloat64 } from \"#src/util/float.js\";\nimport { parseFixedLengthArray } from \"#src/util/json.js\";\nimport { Uint64 } from \"#src/util/uint64.js\";\n\nexport type DataTypeInterval = [number, number] | [Uint64, Uint64];\n\nexport type UnknownDataTypeInterval = [number | Uint64, number | Uint64];\n\nexport const defaultDataTypeRange: Record = {\n [DataType.UINT8]: [0, 0xff],\n [DataType.INT8]: [-0x80, 0x7f],\n [DataType.UINT16]: [0, 0xffff],\n [DataType.INT16]: [-0x8000, 0x7fff],\n [DataType.UINT32]: [0, 0xffffffff],\n [DataType.INT32]: [-0x80000000, 0x7fffffff],\n [DataType.UINT64]: [Uint64.ZERO, new Uint64(0xffffffff, 0xffffffff)],\n [DataType.FLOAT32]: [0, 1],\n};\n\n/**\n * Compute inverse linear interpolation on the interval [0, 1].\n * @param range Values at start and end of interval.\n * @param value Value to interpolate at.\n * @returns Coordinate of interpolated point.\n */\nexport function computeInvlerp(\n range: DataTypeInterval,\n value: number | Uint64,\n): number {\n if (typeof value === \"number\") {\n const minValue = range[0] as number;\n const maxValue = range[1] as number;\n return (value - minValue) / (maxValue - minValue);\n }\n const minValue = range[0] as Uint64;\n const maxValue = range[1] as Uint64;\n let numerator: number;\n if (Uint64.compare(value, minValue) < 0) {\n numerator = -Uint64.subtract(tempUint64, minValue, value).toNumber();\n } else {\n numerator = Uint64.subtract(tempUint64, value, minValue).toNumber();\n }\n let denominator = Uint64.absDifference(\n tempUint64,\n maxValue,\n minValue,\n ).toNumber();\n if (Uint64.compare(minValue, maxValue) > 0) denominator *= -1;\n return numerator / denominator;\n}\n\n/**\n * Compute linear interpolation on the interval [0, 1].\n * @param range Values at start and end of interval.\n * @param dataType\n * @param value Coordinate to interpolate at.\n * @returns Interpolated value.\n */\nexport function computeLerp(\n range: DataTypeInterval,\n dataType: DataType,\n value: number,\n): number | Uint64 {\n if (typeof range[0] === \"number\") {\n const minValue = range[0] as number;\n const maxValue = range[1] as number;\n let result = minValue * (1 - value) + maxValue * value;\n if (dataType !== DataType.FLOAT32) {\n const dataTypeRange = defaultDataTypeRange[dataType];\n result = Math.round(result);\n result = Math.max(dataTypeRange[0] as number, result);\n result = Math.min(dataTypeRange[1] as number, result);\n }\n return result;\n }\n let minValue = range[0] as Uint64;\n let maxValue = range[1] as Uint64;\n if (Uint64.compare(minValue, maxValue) > 0) {\n [minValue, maxValue] = [maxValue, minValue];\n value = 1 - value;\n }\n const scalar = Uint64.subtract(tempUint64, maxValue, minValue).toNumber();\n const result = new Uint64();\n if (value <= 0) {\n tempUint64.setFromNumber(scalar * -value);\n Uint64.subtract(result, minValue, Uint64.min(tempUint64, minValue));\n } else if (value >= 1) {\n tempUint64.setFromNumber(scalar * (value - 1));\n Uint64.add(result, maxValue, tempUint64);\n if (Uint64.less(result, maxValue)) {\n result.low = result.high = 0xffffffff;\n }\n } else {\n tempUint64.setFromNumber(scalar * value);\n Uint64.add(result, minValue, tempUint64);\n if (Uint64.less(result, minValue)) {\n result.low = result.high = 0xffffffff;\n }\n }\n return result;\n}\n\nexport function clampToInterval(\n range: DataTypeInterval,\n value: number | Uint64,\n): number | Uint64 {\n if (typeof value === \"number\") {\n return Math.min(Math.max(range[0] as number, value), range[1] as number);\n }\n return Uint64.min(Uint64.max(range[0] as Uint64, value), range[1] as Uint64);\n}\n\nexport function getClampedInterval(\n bounds: DataTypeInterval,\n range: DataTypeInterval,\n): DataTypeInterval {\n return [\n clampToInterval(bounds, range[0]),\n clampToInterval(bounds, range[1]),\n ] as DataTypeInterval;\n}\n\n// Validates that the lower bound is <= the upper bound.\nexport function validateDataTypeInterval(\n interval: DataTypeInterval,\n): DataTypeInterval {\n if (dataTypeCompare(interval[0], interval[1]) <= 0) return interval;\n throw new Error(`Invalid interval: [${interval[0]}, ${interval[1]}]`);\n}\n\n// Ensures the lower bound is <= the upper bound.\nexport function normalizeDataTypeInterval(\n interval: DataTypeInterval,\n): DataTypeInterval {\n if (dataTypeCompare(interval[0], interval[1]) <= 0) return interval;\n return [interval[1], interval[0]] as DataTypeInterval;\n}\n\nexport function dataTypeCompare(a: number | Uint64, b: number | Uint64) {\n if (typeof a === \"number\") {\n return (a as number) - (b as number);\n }\n return Uint64.compare(a as Uint64, b as Uint64);\n}\n\nconst tempUint64 = new Uint64();\nconst temp2Uint64 = new Uint64();\n\nexport function getClosestEndpoint(\n range: DataTypeInterval,\n value: number | Uint64,\n): number {\n if (typeof value === \"number\") {\n return Math.abs(value - (range[0] as number)) <\n Math.abs(value - (range[1] as number))\n ? 0\n : 1;\n }\n return Uint64.less(\n Uint64.absDifference(tempUint64, range[0] as Uint64, value as Uint64),\n Uint64.absDifference(temp2Uint64, range[1] as Uint64, value as Uint64),\n )\n ? 0\n : 1;\n}\n\nexport function parseDataTypeValue(\n dataType: DataType,\n x: unknown,\n): number | Uint64 {\n let s: string;\n if (typeof x !== \"string\") {\n s = \"\" + x;\n } else {\n s = x;\n }\n switch (dataType) {\n case DataType.UINT64:\n return Uint64.parseString(s);\n case DataType.FLOAT32: {\n const value = parseFloat(s);\n if (!Number.isFinite(value)) {\n throw new Error(`Invalid float32 value: ${JSON.stringify(s)}`);\n }\n return value;\n }\n default: {\n const value = parseInt(s);\n const dataTypeRange = defaultDataTypeRange[dataType];\n if (\n !Number.isInteger(value) ||\n value < (dataTypeRange[0] as number) ||\n value > (dataTypeRange[1] as number)\n ) {\n throw new Error(\n `Invalid ${DataType[dataType].toLowerCase()} value: ${JSON.stringify(\n s,\n )}`,\n );\n }\n return value;\n }\n }\n}\n\nexport function parseUnknownDataTypeValue(x: unknown): number | Uint64 {\n if (typeof x === \"number\") return x;\n if (typeof x === \"string\") {\n const num64 = new Uint64();\n const num = Number(x);\n if (num64.tryParseString(x)) {\n if (num.toString() === num64.toString()) {\n return num;\n }\n return num64;\n }\n if (!Number.isFinite(num)) {\n throw new Error(`Invalid value: ${JSON.stringify(x)}`);\n }\n return num;\n }\n throw new Error(`Invalid value: ${JSON.stringify(x)}`);\n}\n\nexport function parseDataTypeInterval(\n obj: unknown,\n dataType: DataType,\n): DataTypeInterval {\n return parseFixedLengthArray(new Array(2), obj, (x) =>\n parseDataTypeValue(dataType, x),\n ) as DataTypeInterval;\n}\n\nexport function parseUnknownDataTypeInterval(\n obj: unknown,\n): UnknownDataTypeInterval {\n return parseFixedLengthArray(new Array(2), obj, (x) =>\n parseUnknownDataTypeValue(x),\n ) as UnknownDataTypeInterval;\n}\n\nexport function dataTypeIntervalEqual(\n dataType: DataType,\n a: DataTypeInterval,\n b: DataTypeInterval,\n) {\n if (dataType === DataType.UINT64) {\n return (\n Uint64.equal(a[0] as Uint64, b[0] as Uint64) &&\n Uint64.equal(a[1] as Uint64, b[1] as Uint64)\n );\n }\n return a[0] === b[0] && a[1] === b[1];\n}\n\nexport function dataTypeIntervalToJson(\n range: DataTypeInterval,\n dataType: DataType,\n defaultRange = defaultDataTypeRange[dataType],\n) {\n if (dataTypeIntervalEqual(dataType, range, defaultRange)) return undefined;\n if (dataType === DataType.UINT64) {\n return [range[0].toString(), range[1].toString()];\n }\n return range;\n}\n\nexport function dataTypeValueNextAfter(\n dataType: DataType,\n value: number | Uint64,\n sign: 1 | -1,\n): number | Uint64 {\n switch (dataType) {\n case DataType.FLOAT32:\n return nextAfterFloat64(value as number, sign * Infinity);\n case DataType.UINT64: {\n const v = value as Uint64;\n if (sign === -1) {\n if (v.low === 0 && v.high === 0) return v;\n return Uint64.decrement(new Uint64(), v);\n }\n if (v.low === 0xffffffff && v.high === 0xffffffff) return v;\n return Uint64.increment(new Uint64(), v);\n }\n default: {\n const range = defaultDataTypeRange[dataType] as [number, number];\n return Math.max(range[0], Math.min(range[1], (value as number) + sign));\n }\n }\n}\n\n// Returns the offset such that within the floating point range `[-offset, 1+offset]`, there is an\n// equal-sized interval corresponding to each number in `interval`.\n//\n// For dataType=FLOAT32, always returns 0. For integer data types, returns:\n//\n// 0.5 / (1 + abs(interval[1] - interval[0]))\nexport function getIntervalBoundsEffectiveOffset(\n dataType: DataType,\n interval: DataTypeInterval,\n) {\n switch (dataType) {\n case DataType.FLOAT32:\n return 0;\n case DataType.UINT64:\n return (\n 0.5 /\n Uint64.absDifference(\n tempUint64,\n interval[0] as Uint64,\n interval[1] as Uint64,\n ).toNumber()\n );\n default:\n return 0.5 / Math.abs((interval[0] as number) - (interval[1] as number));\n }\n}\n\nexport function getIntervalBoundsEffectiveFraction(\n dataType: DataType,\n interval: DataTypeInterval,\n) {\n switch (dataType) {\n case DataType.FLOAT32:\n return 1;\n case DataType.UINT64: {\n const diff = Uint64.absDifference(\n tempUint64,\n interval[0] as Uint64,\n interval[1] as Uint64,\n ).toNumber();\n return diff / (diff + 1);\n }\n default: {\n const diff = Math.abs((interval[0] as number) - (interval[1] as number));\n return diff / (diff + 1);\n }\n }\n}\n\nexport function convertDataTypeInterval(\n interval: UnknownDataTypeInterval | undefined,\n dataType: DataType,\n): DataTypeInterval {\n if (interval === undefined) {\n return defaultDataTypeRange[dataType];\n }\n let [lower, upper] = interval;\n if (dataType === DataType.UINT64) {\n if (typeof lower === \"number\") {\n lower = Uint64.fromNumber(lower);\n }\n if (typeof upper === \"number\") {\n upper = Uint64.fromNumber(upper);\n }\n return [lower, upper];\n }\n // Ensure that neither lower nor upper is a `Uint64`.\n if (typeof lower !== \"number\") {\n lower = lower.toNumber();\n }\n if (typeof upper !== \"number\") {\n upper = upper.toNumber();\n }\n if (dataType !== DataType.FLOAT32) {\n lower = Math.round(lower);\n upper = Math.round(upper);\n const range = defaultDataTypeRange[dataType] as [number, number];\n if (!Number.isFinite(lower)) {\n lower = range[0];\n } else {\n lower = Math.min(Math.max(range[0], lower), range[1]);\n }\n if (!Number.isFinite(upper)) {\n upper = range[1];\n } else {\n upper = Math.min(Math.max(range[0], upper), range[1]);\n }\n }\n return [lower, upper];\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { TypedArray } from \"#src/util/array.js\";\n\nexport function getRandomHexString(numBits = 128) {\n const numValues = Math.ceil(numBits / 32);\n const data = new Uint32Array(numValues);\n crypto.getRandomValues(data);\n let s = \"\";\n for (let i = 0; i < numValues; ++i) {\n s += (\"00000000\" + data[i].toString(16)).slice(-8);\n }\n return s;\n}\n\n/**\n * Calls crypto.getRandomValues as many times as needed to fill array.\n */\nexport function getRandomValues(array: T): T {\n const byteArray = new Uint8Array(\n array.buffer,\n array.byteOffset,\n array.byteLength,\n );\n const blockSize = 65536;\n for (let i = 0, length = byteArray.length; i < length; i += blockSize) {\n crypto.getRandomValues(\n byteArray.subarray(i, Math.min(length, i + blockSize)),\n );\n }\n return array;\n}\n\nexport function getRandomUint32() {\n const data = new Uint32Array(1);\n crypto.getRandomValues(data);\n return data[0];\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Basic annotation data structures.\n */\n\nimport type {\n BoundingBox,\n CoordinateSpaceTransform,\n WatchableCoordinateSpaceTransform,\n} from \"#src/coordinate_transform.js\";\nimport { WatchableValue } from \"#src/trackable_value.js\";\nimport { arraysEqual } from \"#src/util/array.js\";\nimport {\n packColor,\n parseRGBAColorSpecification,\n parseRGBColorSpecification,\n serializeColor,\n unpackRGB,\n unpackRGBA,\n} from \"#src/util/color.js\";\nimport { DataType } from \"#src/util/data_type.js\";\nimport type { Borrowed } from \"#src/util/disposable.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { Endianness, ENDIANNESS } from \"#src/util/endian.js\";\nimport {\n expectArray,\n parseArray,\n parseFixedLengthArray,\n verifyEnumString,\n verifyFiniteFloat,\n verifyFiniteNonNegativeFloat,\n verifyFloat,\n verifyInt,\n verifyObject,\n verifyObjectProperty,\n verifyOptionalObjectProperty,\n verifyOptionalString,\n verifyString,\n} from \"#src/util/json.js\";\nimport { parseDataTypeValue } from \"#src/util/lerp.js\";\nimport { getRandomHexString } from \"#src/util/random.js\";\nimport { NullarySignal, Signal } from \"#src/util/signal.js\";\nimport { Uint64 } from \"#src/util/uint64.js\";\n\nexport type AnnotationId = string;\n\nexport class AnnotationReference extends RefCounted {\n changed = new NullarySignal();\n\n /**\n * If `undefined`, we are still waiting to look up the result. If `null`, annotation has been\n * deleted.\n */\n value: Annotation | null | undefined;\n\n constructor(public id: AnnotationId) {\n super();\n }\n}\n\nexport enum AnnotationType {\n POINT = 0,\n LINE = 1,\n AXIS_ALIGNED_BOUNDING_BOX = 2,\n ELLIPSOID = 3,\n}\n\nexport const annotationTypes = [\n AnnotationType.POINT,\n AnnotationType.LINE,\n AnnotationType.AXIS_ALIGNED_BOUNDING_BOX,\n AnnotationType.ELLIPSOID,\n];\n\nexport interface AnnotationPropertySpecBase {\n identifier: string;\n description: string | undefined;\n}\n\nexport interface AnnotationColorPropertySpec\n extends AnnotationPropertySpecBase {\n type: \"rgb\" | \"rgba\";\n default: number;\n}\n\nexport interface AnnotationNumericPropertySpec\n extends AnnotationPropertySpecBase {\n type: \"float32\" | \"uint32\" | \"int32\" | \"uint16\" | \"int16\" | \"uint8\" | \"int8\";\n default: number;\n enumValues?: number[];\n enumLabels?: string[];\n min?: number;\n max?: number;\n step?: number;\n tag?: string;\n}\n\nexport interface AnnotationTagPropertySpec\n extends AnnotationNumericPropertySpec {\n type: \"int8\";\n tag: string;\n}\n\nexport const propertyTypeDataType: Record<\n AnnotationPropertySpec[\"type\"],\n DataType | undefined\n> = {\n float32: DataType.FLOAT32,\n uint32: DataType.UINT32,\n int32: DataType.INT32,\n uint16: DataType.UINT16,\n int16: DataType.INT16,\n uint8: DataType.UINT8,\n int8: DataType.INT8,\n rgb: undefined,\n rgba: undefined,\n};\n\nexport type AnnotationPropertySpec =\n | AnnotationColorPropertySpec\n | AnnotationNumericPropertySpec;\n\nexport function isAnnotationNumericPropertySpec(\n spec: AnnotationPropertySpec,\n): spec is AnnotationNumericPropertySpec {\n return spec.type !== \"rgb\" && spec.type !== \"rgba\";\n}\n\nexport function isAnnotationTagPropertySpec(\n spec: AnnotationPropertySpec,\n): spec is AnnotationTagPropertySpec {\n return spec.type === \"uint8\" && spec.tag !== undefined;\n}\n\nexport interface AnnotationPropertyTypeHandler {\n serializedBytes(rank: number): number;\n alignment(rank: number): number;\n serializeCode(property: string, offset: string, rank: number): string;\n deserializeCode(property: string, offset: string, rank: number): string;\n deserializeJson(obj: unknown): number;\n serializeJson(value: number): any;\n}\n\nexport const annotationPropertyTypeHandlers: {\n [K in AnnotationPropertySpec[\"type\"]]: AnnotationPropertyTypeHandler;\n} = {\n rgb: {\n serializedBytes() {\n return 3;\n },\n alignment() {\n return 1;\n },\n serializeCode(property: string, offset: string) {\n return (\n `dv.setUint16(${offset}, ${property}, true);` +\n `dv.setUint8(${offset} + 2, ${property} >>> 16);`\n );\n },\n deserializeCode(property: string, offset: string) {\n return `${property} = dv.getUint16(${offset}, true) | (dv.getUint8(${offset} + 2) << 16);`;\n },\n deserializeJson(obj: unknown) {\n return packColor(parseRGBColorSpecification(obj));\n },\n serializeJson(value: number) {\n return serializeColor(unpackRGB(value));\n },\n },\n rgba: {\n serializedBytes() {\n return 4;\n },\n alignment() {\n return 1;\n },\n serializeCode(property: string, offset: string) {\n return `dv.setUint32(${offset}, ${property}, true);`;\n },\n deserializeCode(property: string, offset: string) {\n return `${property} = dv.getUint32(${offset}, true);`;\n },\n deserializeJson(obj: unknown) {\n return packColor(parseRGBAColorSpecification(obj));\n },\n serializeJson(value: number) {\n return serializeColor(unpackRGBA(value));\n },\n },\n float32: {\n serializedBytes() {\n return 4;\n },\n alignment() {\n return 4;\n },\n serializeCode(property: string, offset: string) {\n return `dv.setFloat32(${offset}, ${property}, isLittleEndian);`;\n },\n deserializeCode(property: string, offset: string) {\n return `${property} = dv.getFloat32(${offset}, isLittleEndian);`;\n },\n deserializeJson(obj: unknown) {\n return verifyFloat(obj);\n },\n serializeJson(value: number) {\n return value;\n },\n },\n uint32: {\n serializedBytes() {\n return 4;\n },\n alignment() {\n return 4;\n },\n serializeCode(property: string, offset: string) {\n return `dv.setUint32(${offset}, ${property}, isLittleEndian);`;\n },\n deserializeCode(property: string, offset: string) {\n return `${property} = dv.getUint32(${offset}, isLittleEndian);`;\n },\n deserializeJson(obj: unknown) {\n return verifyInt(obj);\n },\n serializeJson(value: number) {\n return value;\n },\n },\n int32: {\n serializedBytes() {\n return 4;\n },\n alignment() {\n return 4;\n },\n serializeCode(property: string, offset: string) {\n return `dv.setInt32(${offset}, ${property}, isLittleEndian);`;\n },\n deserializeCode(property: string, offset: string) {\n return `${property} = dv.getInt32(${offset}, isLittleEndian);`;\n },\n deserializeJson(obj: unknown) {\n return verifyInt(obj);\n },\n serializeJson(value: number) {\n return value;\n },\n },\n uint16: {\n serializedBytes() {\n return 2;\n },\n alignment() {\n return 2;\n },\n serializeCode(property: string, offset: string) {\n return `dv.setUint16(${offset}, ${property}, isLittleEndian);`;\n },\n deserializeCode(property: string, offset: string) {\n return `${property} = dv.getUint16(${offset}, isLittleEndian);`;\n },\n deserializeJson(obj: unknown) {\n return verifyInt(obj);\n },\n serializeJson(value: number) {\n return value;\n },\n },\n int16: {\n serializedBytes() {\n return 2;\n },\n alignment() {\n return 2;\n },\n serializeCode(property: string, offset: string) {\n return `dv.setInt16(${offset}, ${property}, isLittleEndian);`;\n },\n deserializeCode(property: string, offset: string) {\n return `${property} = dv.getInt16(${offset}, isLittleEndian);`;\n },\n deserializeJson(obj: unknown) {\n return verifyInt(obj);\n },\n serializeJson(value: number) {\n return value;\n },\n },\n uint8: {\n serializedBytes() {\n return 1;\n },\n alignment() {\n return 1;\n },\n serializeCode(property: string, offset: string) {\n return `dv.setUint8(${offset}, ${property});`;\n },\n deserializeCode(property: string, offset: string) {\n return `${property} = dv.getUint8(${offset});`;\n },\n deserializeJson(obj: unknown) {\n return verifyInt(obj);\n },\n serializeJson(value: number) {\n return value;\n },\n },\n int8: {\n serializedBytes() {\n return 2;\n },\n alignment() {\n return 1;\n },\n serializeCode(property: string, offset: string) {\n return `dv.setInt8(${offset}, ${property});`;\n },\n deserializeCode(property: string, offset: string) {\n return `${property} = dv.getInt8(${offset});`;\n },\n deserializeJson(obj: unknown) {\n return verifyInt(obj);\n },\n serializeJson(value: number) {\n return value;\n },\n },\n};\n\n// Maximum stride value supported by WebGL.\nconst MAX_BUFFER_STRIDE = 255;\n\nexport function getPropertyOffsets(\n rank: number,\n firstGroupInitialOffset: number,\n propertySpecs: readonly Readonly[],\n): {\n serializedBytes: number;\n offsets: { group: number; offset: number }[];\n propertyGroupBytes: number[];\n} {\n let serializedBytes = 0;\n const numProperties = propertySpecs.length;\n const permutation = new Array(numProperties);\n const propertyGroupBytes: number[] = [];\n for (let i = 0; i < numProperties; ++i) {\n permutation[i] = i;\n }\n const getAlignment = (i: number) =>\n annotationPropertyTypeHandlers[propertySpecs[i].type].alignment(rank);\n permutation.sort((i, j) => getAlignment(j) - getAlignment(i));\n let propertyGroupIndex = 0;\n const offsets = new Array<{ group: number; offset: number }>(numProperties);\n let propertyGroupOffset = firstGroupInitialOffset;\n const nextPropertyGroup = () => {\n propertyGroupOffset += (4 - (propertyGroupOffset % 4)) % 4;\n serializedBytes += propertyGroupOffset;\n propertyGroupBytes[propertyGroupIndex] = propertyGroupOffset;\n propertyGroupOffset = 0;\n ++propertyGroupIndex;\n };\n for (let outputIndex = 0; outputIndex < numProperties; ++outputIndex) {\n const propertyIndex = permutation[outputIndex];\n const spec = propertySpecs[propertyIndex];\n const handler = annotationPropertyTypeHandlers[spec.type];\n const numBytes = handler.serializedBytes(rank);\n const alignment = handler.alignment(rank);\n // Check if the property fits in the current property group.\n const alignmentOffset =\n (alignment - (propertyGroupOffset % alignment)) % alignment;\n const newStartOffset = propertyGroupOffset + alignmentOffset;\n const newEndOffset = newStartOffset + numBytes;\n const newAlignedEndOffset = newEndOffset + ((4 - (newEndOffset % 4)) % 4);\n if (newAlignedEndOffset <= MAX_BUFFER_STRIDE) {\n // Property fits\n propertyGroupOffset += alignmentOffset;\n } else {\n // Property does not fit.\n nextPropertyGroup();\n }\n offsets[propertyIndex] = {\n offset: propertyGroupOffset,\n group: propertyGroupIndex,\n };\n propertyGroupOffset += numBytes;\n }\n nextPropertyGroup();\n return { serializedBytes, offsets, propertyGroupBytes };\n}\n\nexport class AnnotationPropertySerializer {\n serializedBytes: number;\n serialize: (\n buffer: DataView,\n offset: number,\n annotationIndex: number,\n annotationCount: number,\n isLittleEndian: boolean,\n properties: any[],\n ) => void;\n deserialize: (\n buffer: DataView,\n offset: number,\n annotationIndex: number,\n annotationCount: number,\n isLittleEndian: boolean,\n properties: any[],\n ) => void;\n propertyGroupBytes: number[];\n constructor(\n public rank: number,\n public firstGroupInitialOffset: number,\n public propertySpecs: readonly Readonly[],\n ) {\n if (propertySpecs.length === 0) {\n this.serializedBytes = firstGroupInitialOffset;\n this.serialize = this.deserialize = () => {};\n this.propertyGroupBytes = [firstGroupInitialOffset];\n return;\n }\n const { serializedBytes, offsets, propertyGroupBytes } = getPropertyOffsets(\n rank,\n firstGroupInitialOffset,\n propertySpecs,\n );\n this.propertyGroupBytes = propertyGroupBytes;\n let groupOffsetCode = \"let groupOffset0 = offset;\";\n for (\n let groupIndex = 1;\n groupIndex < propertyGroupBytes.length;\n ++groupIndex\n ) {\n groupOffsetCode += `let groupOffset${groupIndex} = groupOffset${\n groupIndex - 1\n } + ${propertyGroupBytes[groupIndex - 1]}*annotationCount;`;\n }\n for (\n let groupIndex = 0;\n groupIndex < propertyGroupBytes.length;\n ++groupIndex\n ) {\n groupOffsetCode += `groupOffset${groupIndex} += ${propertyGroupBytes[groupIndex]}*annotationIndex;`;\n }\n let serializeCode = groupOffsetCode;\n let deserializeCode = groupOffsetCode;\n const numProperties = propertySpecs.length;\n for (\n let propertyIndex = 0;\n propertyIndex < numProperties;\n ++propertyIndex\n ) {\n const { group, offset } = offsets[propertyIndex];\n const spec = propertySpecs[propertyIndex];\n const handler = annotationPropertyTypeHandlers[spec.type];\n const propId = `properties[${propertyIndex}]`;\n const offsetExpr = `groupOffset${group} + ${offset}`;\n serializeCode += handler.serializeCode(propId, offsetExpr, rank);\n deserializeCode += handler.deserializeCode(propId, offsetExpr, rank);\n }\n this.serializedBytes = serializedBytes;\n this.serialize = new Function(\n \"dv\",\n \"offset\",\n \"annotationIndex\",\n \"annotationCount\",\n \"isLittleEndian\",\n \"properties\",\n serializeCode,\n ) as any;\n this.deserialize = new Function(\n \"dv\",\n \"offset\",\n \"annotationIndex\",\n \"annotationCount\",\n \"isLittleEndian\",\n \"properties\",\n deserializeCode,\n ) as any;\n }\n}\n\nexport function makeAnnotationPropertySerializers(\n rank: number,\n propertySpecs: readonly Readonly[],\n) {\n const serializers: AnnotationPropertySerializer[] = [];\n for (const annotationType of annotationTypes) {\n const handler = annotationTypeHandlers[annotationType];\n serializers[annotationType] = new AnnotationPropertySerializer(\n rank,\n handler.serializedBytes(rank),\n propertySpecs,\n );\n }\n return serializers;\n}\n\nexport function formatNumericProperty(\n property: AnnotationNumericPropertySpec,\n value: number,\n): string {\n const formattedValue =\n property.type === \"float32\" ? value.toPrecision(6) : value.toString();\n const { enumValues, enumLabels } = property;\n if (enumValues !== undefined) {\n const enumIndex = enumValues.indexOf(value);\n if (enumIndex !== -1) {\n return `${enumLabels![enumIndex]} (${formattedValue})`;\n }\n }\n return formattedValue;\n}\n\nexport function formatAnnotationPropertyValue(\n property: AnnotationPropertySpec,\n value: any,\n): string {\n switch (property.type) {\n case \"rgb\":\n return serializeColor(unpackRGB(value));\n case \"rgba\":\n return serializeColor(unpackRGBA(value));\n default:\n return formatNumericProperty(property, value);\n }\n}\n\nexport function parseAnnotationPropertyId(obj: unknown) {\n const s = verifyString(obj);\n if (s.match(/^[a-z][a-zA-Z0-9_]*$/) === null) {\n throw new Error(`Invalid property identifier: ${JSON.stringify(obj)}`);\n }\n return s;\n}\n\nexport function parseAnnotationPropertyType(obj: unknown) {\n verifyString(obj);\n if (\n !Object.prototype.hasOwnProperty.call(annotationPropertyTypeHandlers, obj)\n ) {\n throw new Error(\"Unsupported property type: $JSON.stringify(obj)}\");\n }\n return obj as AnnotationPropertySpec[\"type\"];\n}\n\nexport function ensureUniqueAnnotationPropertyIds(\n properties: AnnotationPropertySpec[],\n) {\n const ids = new Set();\n for (const p of properties) {\n if (ids.has(p.identifier)) {\n throw new Error(`Duplicate property identifier: ${p.identifier}`);\n }\n ids.add(p.identifier);\n }\n}\n\nfunction parseAnnotationPropertySpec(obj: unknown): AnnotationPropertySpec {\n verifyObject(obj);\n const identifier = verifyObjectProperty(obj, \"id\", parseAnnotationPropertyId);\n const type = verifyObjectProperty(obj, \"type\", parseAnnotationPropertyType);\n const description = verifyOptionalObjectProperty(\n obj,\n \"description\",\n verifyString,\n );\n const defaultValue = verifyOptionalObjectProperty(\n obj,\n \"default\",\n (x) => annotationPropertyTypeHandlers[type].deserializeJson(x),\n 0,\n );\n let enumValues: number[] | undefined;\n let enumLabels: string[] | undefined;\n let tag: string | undefined;\n switch (type) {\n case \"rgb\":\n case \"rgba\":\n break;\n default: {\n const dataType: DataType = DataType[type.toUpperCase() as any] as any;\n enumValues = verifyOptionalObjectProperty(\n obj,\n \"enum_values\",\n (valuesObj) =>\n parseArray(\n valuesObj,\n (x) => parseDataTypeValue(dataType, x) as number,\n ),\n );\n if (enumValues !== undefined) {\n enumLabels = verifyObjectProperty(obj, \"enum_labels\", (labelsObj) =>\n parseFixedLengthArray(\n new Array(enumValues!.length),\n labelsObj,\n verifyString,\n ),\n );\n }\n tag = verifyOptionalObjectProperty(obj, \"tag\", verifyString);\n }\n }\n return {\n type,\n identifier,\n description,\n default: defaultValue,\n enumValues,\n enumLabels,\n tag,\n } as AnnotationPropertySpec;\n}\n\nfunction annotationPropertySpecToJson(spec: AnnotationPropertySpec) {\n const defaultValue = spec.default;\n const isNumeric = isAnnotationNumericPropertySpec(spec);\n const tag = isNumeric ? spec.tag : undefined;\n const enum_values = isNumeric ? spec.enumValues : undefined;\n const enum_labels = isNumeric ? spec.enumLabels : undefined;\n return {\n id: spec.identifier,\n description: spec.description,\n type: spec.type,\n tag,\n enum_values,\n enum_labels,\n default:\n defaultValue === 0\n ? undefined\n : annotationPropertyTypeHandlers[spec.type].serializeJson(defaultValue),\n };\n}\n\nexport function annotationPropertySpecsToJson(\n specs: AnnotationPropertySpec[] | undefined,\n) {\n if (specs === undefined || specs.length === 0) return undefined;\n return specs.map(annotationPropertySpecToJson);\n}\n\nexport function parseAnnotationPropertySpecs(obj: unknown) {\n if (obj === undefined) return [];\n const properties = parseArray(obj, parseAnnotationPropertySpec);\n ensureUniqueAnnotationPropertyIds(properties);\n return properties;\n}\n\nexport interface AnnotationBase {\n /**\n * If equal to `undefined`, then the description is unknown (possibly still being loaded). If\n * equal to `null`, then there is no description.\n */\n description?: string | undefined | null;\n\n id: AnnotationId;\n type: AnnotationType;\n\n relatedSegments?: Uint64[][];\n properties: any[];\n}\n\nexport interface Line extends AnnotationBase {\n pointA: Float32Array;\n pointB: Float32Array;\n type: AnnotationType.LINE;\n}\n\nexport interface Point extends AnnotationBase {\n point: Float32Array;\n type: AnnotationType.POINT;\n}\n\nexport interface AxisAlignedBoundingBox extends AnnotationBase {\n pointA: Float32Array;\n pointB: Float32Array;\n type: AnnotationType.AXIS_ALIGNED_BOUNDING_BOX;\n}\n\nexport interface Ellipsoid extends AnnotationBase {\n center: Float32Array;\n radii: Float32Array;\n type: AnnotationType.ELLIPSOID;\n}\n\nexport type Annotation = Line | Point | AxisAlignedBoundingBox | Ellipsoid;\n\nexport interface AnnotationTypeHandler {\n icon: string;\n description: string;\n toJSON: (annotation: T, rank: number) => any;\n restoreState: (annotation: T, obj: any, rank: number) => void;\n serializedBytes: (rank: number) => number;\n serialize: (\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n annotation: T,\n ) => void;\n deserialize: (\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n id: string,\n ) => T;\n visitGeometry: (\n annotation: T,\n callback: (vec: Float32Array, isVector: boolean) => void,\n ) => void;\n}\n\nfunction serializeFloatVector(\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n vec: Float32Array,\n) {\n for (let i = 0; i < rank; ++i) {\n buffer.setFloat32(offset, vec[i], isLittleEndian);\n offset += 4;\n }\n return offset;\n}\n\nfunction serializeTwoFloatVectors(\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n vecA: Float32Array,\n vecB: Float32Array,\n) {\n offset = serializeFloatVector(buffer, offset, isLittleEndian, rank, vecA);\n offset = serializeFloatVector(buffer, offset, isLittleEndian, rank, vecB);\n return offset;\n}\n\nfunction deserializeFloatVector(\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n vec: Float32Array,\n) {\n for (let i = 0; i < rank; ++i) {\n vec[i] = buffer.getFloat32(offset, isLittleEndian);\n offset += 4;\n }\n return offset;\n}\n\nfunction deserializeTwoFloatVectors(\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n vecA: Float32Array,\n vecB: Float32Array,\n) {\n offset = deserializeFloatVector(buffer, offset, isLittleEndian, rank, vecA);\n offset = deserializeFloatVector(buffer, offset, isLittleEndian, rank, vecB);\n return offset;\n}\n\nexport const annotationTypeHandlers: Record<\n AnnotationType,\n AnnotationTypeHandler\n> = {\n [AnnotationType.LINE]: {\n icon: \"ꕹ\",\n description: \"Line\",\n toJSON(annotation: Line) {\n return {\n pointA: Array.from(annotation.pointA),\n pointB: Array.from(annotation.pointB),\n };\n },\n restoreState(annotation: Line, obj: any, rank: number) {\n annotation.pointA = verifyObjectProperty(obj, \"pointA\", (x) =>\n parseFixedLengthArray(new Float32Array(rank), x, verifyFiniteFloat),\n );\n annotation.pointB = verifyObjectProperty(obj, \"pointB\", (x) =>\n parseFixedLengthArray(new Float32Array(rank), x, verifyFiniteFloat),\n );\n },\n serializedBytes(rank: number) {\n return 2 * 4 * rank;\n },\n serialize(\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n annotation: Line,\n ) {\n serializeTwoFloatVectors(\n buffer,\n offset,\n isLittleEndian,\n rank,\n annotation.pointA,\n annotation.pointB,\n );\n },\n deserialize: (\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n id: string,\n ): Line => {\n const pointA = new Float32Array(rank);\n const pointB = new Float32Array(rank);\n deserializeTwoFloatVectors(\n buffer,\n offset,\n isLittleEndian,\n rank,\n pointA,\n pointB,\n );\n return { type: AnnotationType.LINE, pointA, pointB, id, properties: [] };\n },\n visitGeometry(annotation: Line, callback) {\n callback(annotation.pointA, false);\n callback(annotation.pointB, false);\n },\n },\n [AnnotationType.POINT]: {\n icon: \"⚬\",\n description: \"Point\",\n toJSON: (annotation: Point) => {\n return {\n point: Array.from(annotation.point),\n };\n },\n restoreState: (annotation: Point, obj: any, rank: number) => {\n annotation.point = verifyObjectProperty(obj, \"point\", (x) =>\n parseFixedLengthArray(new Float32Array(rank), x, verifyFiniteFloat),\n );\n },\n serializedBytes: (rank) => rank * 4,\n serialize: (\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n annotation: Point,\n ) => {\n serializeFloatVector(\n buffer,\n offset,\n isLittleEndian,\n rank,\n annotation.point,\n );\n },\n deserialize: (\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n id: string,\n ): Point => {\n const point = new Float32Array(rank);\n deserializeFloatVector(buffer, offset, isLittleEndian, rank, point);\n return { type: AnnotationType.POINT, point, id, properties: [] };\n },\n visitGeometry(annotation: Point, callback) {\n callback(annotation.point, false);\n },\n },\n [AnnotationType.AXIS_ALIGNED_BOUNDING_BOX]: {\n icon: \"❑\",\n description: \"Bounding Box\",\n toJSON: (annotation: AxisAlignedBoundingBox) => {\n return {\n pointA: Array.from(annotation.pointA),\n pointB: Array.from(annotation.pointB),\n };\n },\n restoreState: (\n annotation: AxisAlignedBoundingBox,\n obj: any,\n rank: number,\n ) => {\n annotation.pointA = verifyObjectProperty(obj, \"pointA\", (x) =>\n parseFixedLengthArray(new Float32Array(rank), x, verifyFiniteFloat),\n );\n annotation.pointB = verifyObjectProperty(obj, \"pointB\", (x) =>\n parseFixedLengthArray(new Float32Array(rank), x, verifyFiniteFloat),\n );\n },\n serializedBytes: (rank) => 2 * 4 * rank,\n serialize(\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n annotation: AxisAlignedBoundingBox,\n ) {\n serializeTwoFloatVectors(\n buffer,\n offset,\n isLittleEndian,\n rank,\n annotation.pointA,\n annotation.pointB,\n );\n },\n deserialize: (\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n id: string,\n ): AxisAlignedBoundingBox => {\n const pointA = new Float32Array(rank);\n const pointB = new Float32Array(rank);\n deserializeTwoFloatVectors(\n buffer,\n offset,\n isLittleEndian,\n rank,\n pointA,\n pointB,\n );\n return {\n type: AnnotationType.AXIS_ALIGNED_BOUNDING_BOX,\n pointA,\n pointB,\n id,\n properties: [],\n };\n },\n visitGeometry(annotation: AxisAlignedBoundingBox, callback) {\n callback(annotation.pointA, false);\n callback(annotation.pointB, false);\n },\n },\n [AnnotationType.ELLIPSOID]: {\n icon: \"◎\",\n description: \"Ellipsoid\",\n toJSON: (annotation: Ellipsoid) => {\n return {\n center: Array.from(annotation.center),\n radii: Array.from(annotation.radii),\n };\n },\n restoreState: (annotation: Ellipsoid, obj: any, rank: number) => {\n annotation.center = verifyObjectProperty(obj, \"center\", (x) =>\n parseFixedLengthArray(new Float32Array(rank), x, verifyFiniteFloat),\n );\n annotation.radii = verifyObjectProperty(obj, \"radii\", (x) =>\n parseFixedLengthArray(\n new Float32Array(rank),\n x,\n verifyFiniteNonNegativeFloat,\n ),\n );\n },\n serializedBytes: (rank) => 2 * 4 * rank,\n serialize(\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n annotation: Ellipsoid,\n ) {\n serializeTwoFloatVectors(\n buffer,\n offset,\n isLittleEndian,\n rank,\n annotation.center,\n annotation.radii,\n );\n },\n deserialize: (\n buffer: DataView,\n offset: number,\n isLittleEndian: boolean,\n rank: number,\n id: string,\n ): Ellipsoid => {\n const center = new Float32Array(rank);\n const radii = new Float32Array(rank);\n deserializeTwoFloatVectors(\n buffer,\n offset,\n isLittleEndian,\n rank,\n center,\n radii,\n );\n return {\n type: AnnotationType.ELLIPSOID,\n center,\n radii,\n id,\n properties: [],\n };\n },\n visitGeometry(annotation: Ellipsoid, callback) {\n callback(annotation.center, false);\n callback(annotation.radii, true);\n },\n },\n};\n\nexport interface AnnotationSchema {\n rank: number;\n relationships: readonly string[];\n properties: WatchableValue[]>;\n}\n\nexport function annotationToJson(\n annotation: Annotation,\n schema: AnnotationSchema,\n) {\n const result = annotationTypeHandlers[annotation.type].toJSON(\n annotation,\n schema.rank,\n );\n result.type = AnnotationType[annotation.type].toLowerCase();\n result.id = annotation.id;\n result.description = annotation.description || undefined;\n const { relatedSegments } = annotation;\n if (relatedSegments?.some((x) => x.length !== 0)) {\n result.segments = relatedSegments.map((segments) =>\n segments.map((x) => x.toString()),\n );\n }\n const propertySpecs = schema.properties.value;\n if (propertySpecs.length !== 0) {\n result.props = annotation.properties.map((prop, i) =>\n annotationPropertyTypeHandlers[propertySpecs[i].type].serializeJson(prop),\n );\n }\n return result;\n}\n\nfunction restoreAnnotation(\n obj: any,\n schema: AnnotationSchema,\n allowMissingId = false,\n): Annotation {\n verifyObject(obj);\n const type = verifyObjectProperty(obj, \"type\", (x) =>\n verifyEnumString(x, AnnotationType),\n );\n const id =\n verifyObjectProperty(\n obj,\n \"id\",\n allowMissingId ? verifyOptionalString : verifyString,\n ) || makeAnnotationId();\n const relatedSegments = verifyObjectProperty(obj, \"segments\", (relObj) => {\n if (relObj === undefined) {\n return schema.relationships.map(() => []);\n }\n const a = expectArray(relObj);\n if (a.length === 0) {\n return schema.relationships.map(() => []);\n }\n if (schema.relationships.length === 1 && !Array.isArray(a[0])) {\n return [parseArray(a, (x) => Uint64.parseString(x))];\n }\n return parseArray(\n expectArray(relObj, schema.relationships.length),\n (segments) => parseArray(segments, (y) => Uint64.parseString(y)),\n );\n });\n const properties = verifyObjectProperty(obj, \"props\", (propsObj) => {\n const propSpecs = schema.properties.value;\n if (propsObj === undefined) return propSpecs.map((x) => x.default);\n return parseArray(expectArray(propsObj, propSpecs.length), (x, i) =>\n annotationPropertyTypeHandlers[propSpecs[i].type].deserializeJson(x),\n );\n });\n const result: Annotation = {\n id,\n description: verifyObjectProperty(obj, \"description\", verifyOptionalString),\n relatedSegments,\n properties,\n type,\n } as Annotation;\n annotationTypeHandlers[type].restoreState(result, obj, schema.rank);\n return result;\n}\n\nexport interface AnnotationSourceSignals {\n changed: NullarySignal;\n childAdded: Signal<(annotation: Annotation) => void>;\n childUpdated: Signal<(annotation: Annotation) => void>;\n childCommitted: Signal<(annotationId: string) => void>;\n childDeleted: Signal<(annotationId: string) => void>;\n}\n\nexport class AnnotationSource\n extends RefCounted\n implements AnnotationSourceSignals\n{\n protected annotationMap = new Map();\n changed = new NullarySignal();\n readonly = false;\n childAdded = new Signal<(annotation: Annotation) => void>();\n childUpdated = new Signal<(annotation: Annotation) => void>();\n childCommitted = new Signal<(annotationId: string) => void>();\n childDeleted = new Signal<(annotationId: string) => void>();\n\n public pending = new Set();\n\n protected rank_: number;\n\n get rank() {\n return this.rank_;\n }\n\n annotationPropertySerializers: AnnotationPropertySerializer[];\n\n constructor(\n rank: number,\n public readonly relationships: readonly string[] = [],\n public readonly properties: WatchableValue<\n readonly Readonly[]\n > = new WatchableValue([]),\n ) {\n super();\n this.rank_ = rank;\n this.annotationPropertySerializers = makeAnnotationPropertySerializers(\n rank,\n properties.value,\n );\n }\n\n hasNonSerializedProperties() {\n return true;\n }\n\n add(annotation: Annotation, commit = true): AnnotationReference {\n this.ensureUpdated();\n if (!annotation.id) {\n annotation.id = makeAnnotationId();\n } else if (this.annotationMap.has(annotation.id)) {\n throw new Error(\n `Annotation id already exists: ${JSON.stringify(annotation.id)}.`,\n );\n }\n this.annotationMap.set(annotation.id, annotation);\n if (!commit) {\n this.pending.add(annotation.id);\n }\n this.changed.dispatch();\n this.childAdded.dispatch(annotation);\n if (commit) {\n this.childCommitted.dispatch(annotation.id);\n }\n return this.getReference(annotation.id);\n }\n\n commit(reference: AnnotationReference): void {\n this.ensureUpdated();\n const id = reference.id;\n this.pending.delete(id);\n this.changed.dispatch();\n this.childCommitted.dispatch(id);\n }\n\n update(reference: AnnotationReference, annotation: Annotation) {\n this.ensureUpdated();\n if (reference.value === null) {\n throw new Error(\"Annotation already deleted.\");\n }\n reference.value = annotation;\n this.annotationMap.set(annotation.id, annotation);\n reference.changed.dispatch();\n this.changed.dispatch();\n this.childUpdated.dispatch(annotation);\n }\n\n [Symbol.iterator]() {\n this.ensureUpdated();\n return this.annotationMap.values();\n }\n\n get(id: AnnotationId) {\n this.ensureUpdated();\n return this.annotationMap.get(id);\n }\n\n delete(reference: AnnotationReference) {\n if (reference.value === null) {\n return;\n }\n reference.value = null;\n this.annotationMap.delete(reference.id);\n this.pending.delete(reference.id);\n reference.changed.dispatch();\n this.changed.dispatch();\n this.childDeleted.dispatch(reference.id);\n }\n\n getReference(id: AnnotationId): AnnotationReference {\n let existing = this.references.get(id);\n if (existing !== undefined) {\n return existing.addRef();\n }\n existing = new AnnotationReference(id);\n existing.value = this.annotationMap.get(id) || null;\n this.references.set(id, existing);\n existing.registerDisposer(() => {\n this.references.delete(id);\n });\n return existing;\n }\n\n references = new Map>();\n\n protected ensureUpdated() {}\n\n toJSON() {\n this.ensureUpdated();\n const result: any[] = [];\n const { pending } = this;\n for (const annotation of this) {\n if (pending.has(annotation.id)) {\n // Don't serialize uncommitted annotations.\n continue;\n }\n result.push(annotationToJson(annotation, this));\n }\n return result;\n }\n\n clear() {\n this.annotationMap.clear();\n this.pending.clear();\n this.changed.dispatch();\n }\n\n restoreState(obj: any) {\n this.ensureUpdated();\n const { annotationMap } = this;\n annotationMap.clear();\n this.pending.clear();\n if (obj !== undefined) {\n parseArray(obj, (x) => {\n const annotation = restoreAnnotation(x, this);\n annotationMap.set(annotation.id, annotation);\n });\n }\n for (const reference of this.references.values()) {\n const { id } = reference;\n const value = annotationMap.get(id);\n reference.value = value || null;\n reference.changed.dispatch();\n }\n this.changed.dispatch();\n }\n\n reset() {\n this.clear();\n }\n}\n\nexport class LocalAnnotationSource extends AnnotationSource {\n private curCoordinateTransform: CoordinateSpaceTransform;\n\n get rank() {\n this.ensureUpdated();\n return this.rank_;\n }\n\n constructor(\n public watchableTransform: WatchableCoordinateSpaceTransform,\n public readonly properties: WatchableValue<\n AnnotationPropertySpec[]\n > = new WatchableValue([]),\n relationships: string[],\n ) {\n super(watchableTransform.value.sourceRank, relationships, properties);\n this.curCoordinateTransform = watchableTransform.value;\n this.registerDisposer(\n watchableTransform.changed.add(() => this.ensureUpdated()),\n );\n\n this.registerDisposer(\n properties.changed.add(() => {\n this.updateAnnotationPropertySerializers();\n this.changed.dispatch();\n }),\n );\n }\n\n updateAnnotationPropertySerializers() {\n this.annotationPropertySerializers = makeAnnotationPropertySerializers(\n this.rank_,\n this.properties.value,\n );\n }\n\n addProperty(property: AnnotationPropertySpec) {\n this.properties.value.push(property);\n for (const annotation of this) {\n annotation.properties.push(property.default);\n }\n this.properties.changed.dispatch();\n }\n\n removeProperty(identifier: string) {\n const propertyIndex = this.properties.value.findIndex(\n (x) => x.identifier === identifier,\n );\n this.properties.value.splice(propertyIndex, 1);\n for (const annotation of this) {\n annotation.properties.splice(propertyIndex, 1);\n }\n this.properties.changed.dispatch();\n }\n\n getTagProperties = () => {\n const { properties } = this;\n return properties.value.filter(isAnnotationTagPropertySpec);\n };\n\n ensureUpdated() {\n const transform = this.watchableTransform.value;\n const { curCoordinateTransform } = this;\n if (transform === curCoordinateTransform) return;\n this.curCoordinateTransform = transform;\n const sourceRank = transform.sourceRank;\n const oldSourceRank = curCoordinateTransform.sourceRank;\n if (\n oldSourceRank === sourceRank &&\n (curCoordinateTransform.inputSpace === transform.inputSpace ||\n arraysEqual(\n curCoordinateTransform.inputSpace.ids.slice(0, sourceRank),\n transform.inputSpace.ids.slice(0, sourceRank),\n ))\n ) {\n return;\n }\n const { ids: newIds } = transform.inputSpace;\n const oldIds = curCoordinateTransform.inputSpace.ids;\n const newToOldDims: number[] = [];\n for (let newDim = 0; newDim < sourceRank; ++newDim) {\n let oldDim = oldIds.indexOf(newIds[newDim]);\n if (oldDim >= oldSourceRank) {\n oldDim = -1;\n }\n newToOldDims.push(oldDim);\n }\n const mapVector = (radii: Float32Array) => {\n const newRadii = new Float32Array(sourceRank);\n for (let i = 0; i < sourceRank; ++i) {\n const oldDim = newToOldDims[i];\n newRadii[i] = oldDim === -1 ? 0 : radii[i];\n }\n return newRadii;\n };\n\n for (const annotation of this.annotationMap.values()) {\n switch (annotation.type) {\n case AnnotationType.POINT:\n annotation.point = mapVector(annotation.point);\n break;\n case AnnotationType.LINE:\n case AnnotationType.AXIS_ALIGNED_BOUNDING_BOX:\n annotation.pointA = mapVector(annotation.pointA);\n annotation.pointB = mapVector(annotation.pointB);\n break;\n case AnnotationType.ELLIPSOID:\n annotation.center = mapVector(annotation.center);\n annotation.radii = mapVector(annotation.radii);\n break;\n }\n }\n if (this.rank_ !== sourceRank) {\n this.rank_ = sourceRank;\n this.updateAnnotationPropertySerializers();\n }\n this.changed.dispatch();\n }\n}\n\nexport const DATA_BOUNDS_DESCRIPTION = \"Data Bounds\";\n\nexport function makeAnnotationId() {\n return getRandomHexString(160);\n}\n\nexport function makeDataBoundsBoundingBoxAnnotation(\n box: BoundingBox,\n): AxisAlignedBoundingBox {\n return {\n type: AnnotationType.AXIS_ALIGNED_BOUNDING_BOX,\n id: \"data-bounds\",\n description: DATA_BOUNDS_DESCRIPTION,\n pointA: new Float32Array(box.lowerBounds),\n pointB: new Float32Array(box.upperBounds),\n properties: [],\n };\n}\n\nexport function makeDataBoundsBoundingBoxAnnotationSet(\n box: BoundingBox,\n): AnnotationSource {\n const annotationSource = new AnnotationSource(box.lowerBounds.length);\n annotationSource.readonly = true;\n annotationSource.add(makeDataBoundsBoundingBoxAnnotation(box));\n return annotationSource;\n}\n\nexport interface SerializedAnnotations {\n data: Uint8Array;\n typeToIds: string[][];\n typeToOffset: number[];\n typeToIdMaps: Map[];\n}\n\nfunction serializeAnnotations(\n allAnnotations: Annotation[][],\n propertySerializers: AnnotationPropertySerializer[],\n): SerializedAnnotations {\n let totalBytes = 0;\n const typeToOffset: number[] = [];\n for (const annotationType of annotationTypes) {\n const propertySerializer = propertySerializers[annotationType];\n const serializedPropertiesBytes = propertySerializer.serializedBytes;\n typeToOffset[annotationType] = totalBytes;\n const annotations: Annotation[] = allAnnotations[annotationType];\n const count = annotations.length;\n totalBytes += serializedPropertiesBytes * count;\n }\n const typeToIds: string[][] = [];\n const typeToIdMaps: Map[] = [];\n const data = new ArrayBuffer(totalBytes);\n const dataView = new DataView(data);\n const isLittleEndian = ENDIANNESS === Endianness.LITTLE;\n for (const annotationType of annotationTypes) {\n const propertySerializer = propertySerializers[annotationType];\n const { rank } = propertySerializer;\n const serializeProperties = propertySerializer.serialize;\n const annotations: Annotation[] = allAnnotations[annotationType];\n typeToIds[annotationType] = annotations.map((x) => x.id);\n typeToIdMaps[annotationType] = new Map(\n annotations.map((x, i) => [x.id, i]),\n );\n const handler = annotationTypeHandlers[annotationType];\n const serialize = handler.serialize;\n const offset = typeToOffset[annotationType];\n const geometryDataStride = propertySerializer.propertyGroupBytes[0];\n for (let i = 0, count = annotations.length; i < count; ++i) {\n const annotation = annotations[i];\n serialize(\n dataView,\n offset + i * geometryDataStride,\n isLittleEndian,\n rank,\n annotation,\n );\n serializeProperties(\n dataView,\n offset,\n i,\n count,\n isLittleEndian,\n annotation.properties,\n );\n }\n }\n return { data: new Uint8Array(data), typeToIds, typeToOffset, typeToIdMaps };\n}\n\nexport class AnnotationSerializer {\n annotations: [Point[], Line[], AxisAlignedBoundingBox[], Ellipsoid[]] = [\n [],\n [],\n [],\n [],\n ];\n constructor(public propertySerializers: AnnotationPropertySerializer[]) {}\n add(annotation: Annotation) {\n (this.annotations[annotation.type]).push(annotation);\n }\n serialize(): SerializedAnnotations {\n return serializeAnnotations(this.annotations, this.propertySerializers);\n }\n}\n\nexport function fixAnnotationAfterStructuredCloning(obj: Annotation | null) {\n if (obj == null) {\n return obj;\n }\n const { relatedSegments } = obj;\n if (relatedSegments !== undefined) {\n for (\n let i = 0, numRelationships = relatedSegments.length;\n i < numRelationships;\n ++i\n ) {\n const segments = relatedSegments[i];\n if (segments === undefined) continue;\n relatedSegments[i] = segments.map(\n (x: { low: number; high: number }) => new Uint64(x.low, x.high),\n );\n }\n }\n return obj;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { binarySearchLowerBound } from \"#src/util/array.js\";\n\nexport interface SiPrefix {\n readonly prefix: string;\n readonly exponent: number;\n readonly longPrefix?: string;\n}\n\nexport const preferredSiPrefixes: readonly SiPrefix[] = [\n { prefix: \"Y\", exponent: 24, longPrefix: \"yotta\" },\n { prefix: \"Z\", exponent: 21, longPrefix: \"zetta\" },\n { prefix: \"E\", exponent: 18, longPrefix: \"exa\" },\n { prefix: \"P\", exponent: 15, longPrefix: \"peta\" },\n { prefix: \"T\", exponent: 12, longPrefix: \"tera\" },\n { prefix: \"G\", exponent: 9, longPrefix: \"giga\" },\n { prefix: \"M\", exponent: 6, longPrefix: \"mega\" },\n { prefix: \"k\", exponent: 3, longPrefix: \"kilo\" },\n { prefix: \"\", exponent: 0, longPrefix: \"\" },\n { prefix: \"m\", exponent: -3, longPrefix: \"milli\" },\n { prefix: \"µ\", exponent: -6, longPrefix: \"micro\" },\n { prefix: \"n\", exponent: -9, longPrefix: \"nano\" },\n { prefix: \"p\", exponent: -12, longPrefix: \"pico\" },\n { prefix: \"f\", exponent: -15, longPrefix: \"femto\" },\n { prefix: \"a\", exponent: -18, longPrefix: \"atto\" },\n { prefix: \"z\", exponent: -21, longPrefix: \"zepto\" },\n { prefix: \"y\", exponent: -24, longPrefix: \"yocto\" },\n];\n\nexport const allSiPrefixes: readonly SiPrefix[] = [\n ...preferredSiPrefixes,\n { prefix: \"h\", exponent: 2, longPrefix: \"hecto\" },\n { prefix: \"da\", exponent: 1, longPrefix: \"deca\" },\n { prefix: \"d\", exponent: -1, longPrefix: \"deci\" },\n { prefix: \"c\", exponent: -2, longPrefix: \"centi\" },\n];\n\nconst siPrefixesWithAlternatives: readonly SiPrefix[] = [\n { prefix: \"u\", exponent: -6 }, // Also allow \"u\" for micro\n ...allSiPrefixes,\n];\n\nexport const supportedUnits = new Map<\n string,\n { unit: string; exponent: number }\n>();\nsupportedUnits.set(\"\", { unit: \"\", exponent: 0 });\nexport const exponentToPrefix = new Map();\nfor (const { prefix, exponent } of siPrefixesWithAlternatives) {\n exponentToPrefix.set(exponent, prefix);\n for (const unit of [\"m\", \"s\", \"Hz\", \"rad/s\"]) {\n supportedUnits.set(`${prefix}${unit}`, { unit, exponent });\n }\n}\n\nexport function pickSiPrefix(x: number): SiPrefix {\n const exponent = Math.log10(x);\n const numPrefixes = preferredSiPrefixes.length;\n const i = binarySearchLowerBound(\n 0,\n numPrefixes,\n (i) => preferredSiPrefixes[i].exponent <= exponent,\n );\n return preferredSiPrefixes[Math.min(i, numPrefixes - 1)];\n}\n\ninterface FormatScaleWithUnitOptions {\n precision?: number;\n elide1?: boolean;\n}\n\nexport function formatScaleWithUnit(\n scale: number,\n unit: string,\n options: FormatScaleWithUnitOptions = {},\n): { scale: string; prefix: string; unit: string } {\n const { precision = 6, elide1 = true } = options;\n let adjustedScale = scale;\n let prefix = \"\";\n if (unit !== \"\") {\n const result = pickSiPrefix(scale);\n prefix = result.prefix;\n adjustedScale = scaleByExp10(scale, -result.exponent);\n }\n if (elide1 && adjustedScale === 1) {\n return { scale: \"\", unit, prefix };\n }\n let scaleString: string;\n if (precision !== 0) {\n if (adjustedScale < 1 || adjustedScale >= 1000) {\n scaleString = adjustedScale.toPrecision(precision);\n } else {\n scaleString = adjustedScale.toFixed(precision);\n }\n const eIndex = scaleString.indexOf(\"e\");\n let numString: string;\n let exponentString: string;\n if (eIndex !== -1) {\n numString = scaleString.substring(0, eIndex);\n exponentString = scaleString.substring(eIndex);\n } else {\n numString = scaleString;\n exponentString = \"\";\n }\n const m = numString.match(/.*\\.(?:[0-9]*[1-9])?(0+)$/);\n if (m !== null) {\n numString = numString.substring(0, numString.length - m[1].length);\n if (numString.endsWith(\".\")) {\n numString = numString.substring(0, numString.length - 1);\n }\n scaleString = numString + exponentString;\n }\n } else {\n scaleString = adjustedScale.toString();\n }\n return {\n scale: scaleString,\n unit,\n prefix,\n };\n}\n\nexport function formatScaleWithUnitAsString(\n scale: number,\n unit: string,\n options?: FormatScaleWithUnitOptions,\n): string {\n const {\n scale: formattedScale,\n unit: formattedUnit,\n prefix,\n } = formatScaleWithUnit(scale, unit, options);\n return `${formattedScale}${prefix}${formattedUnit}`;\n}\n\nexport function parseScale(s: string) {\n if (s === \"\") {\n return { scale: 1, unit: \"\" };\n }\n const match = s.match(\n /^((?:0|[1-9]\\d*)(?:\\.\\d+)?(?:[eE][+-]?\\d+)?)?([µa-zA-Z]+)?$/,\n );\n if (match === null) return undefined;\n const scaleString = match[1];\n let scale = scaleString === undefined ? 1 : Number(scaleString);\n if (Number.isNaN(scale)) return undefined;\n let unit = \"\";\n if (match[2] !== undefined) {\n const result = supportedUnits.get(match[2]);\n if (result === undefined) {\n return undefined;\n }\n unit = result.unit;\n if (result.exponent > 0) {\n scale *= 10 ** result.exponent;\n } else {\n scale /= 10 ** -result.exponent;\n }\n }\n if (scale <= 0 || !Number.isFinite(scale)) return undefined;\n return { scale, unit };\n}\n\nexport function unitFromJson(x: unknown) {\n const result = supportedUnits.get(x as string);\n if (result === undefined) {\n throw new Error(`Invalid unit: ${JSON.stringify(x)}`);\n }\n return result;\n}\n\n/**\n * Returns `scale * 10**exponent`, but uses division for negative exponents to reduce loss of\n * precision.\n */\nexport function scaleByExp10(scale: number, exponent: number) {\n if (exponent >= 0) return scale * 10 ** exponent;\n return scale / 10 ** -exponent;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { TypedArray } from \"#src/util/array.js\";\n\nexport function equal(a: T, b: U) {\n const n = a.length;\n for (let i = 0; i < n; ++i) {\n if (a[i] !== b[i]) return false;\n }\n return true;\n}\n\nexport function add<\n Out extends TypedArray,\n A extends TypedArray,\n B extends TypedArray,\n>(out: Out, a: A, b: B) {\n const rank = out.length;\n for (let i = 0; i < rank; ++i) {\n out[i] = a[i] + b[i];\n }\n return out;\n}\nexport function subtract<\n Out extends TypedArray,\n A extends TypedArray,\n B extends TypedArray,\n>(out: Out, a: A, b: B) {\n const rank = out.length;\n for (let i = 0; i < rank; ++i) {\n out[i] = a[i] - b[i];\n }\n return out;\n}\nexport function multiply<\n Out extends TypedArray,\n A extends TypedArray,\n B extends TypedArray,\n>(out: Out, a: A, b: B) {\n const rank = out.length;\n for (let i = 0; i < rank; ++i) {\n out[i] = a[i] * b[i];\n }\n return out;\n}\nexport function divide<\n Out extends TypedArray,\n A extends TypedArray,\n B extends TypedArray,\n>(out: Out, a: A, b: B) {\n const rank = out.length;\n for (let i = 0; i < rank; ++i) {\n out[i] = a[i] / b[i];\n }\n return out;\n}\nexport function scaleAndAdd<\n Out extends TypedArray,\n A extends TypedArray,\n B extends TypedArray,\n>(out: Out, a: A, b: B, scale: number) {\n const rank = out.length;\n for (let i = 0; i < rank; ++i) {\n out[i] = a[i] + b[i] * scale;\n }\n return out;\n}\nexport function scale(\n out: Out,\n a: A,\n scale: number,\n) {\n const rank = out.length;\n for (let i = 0; i < rank; ++i) {\n out[i] = a[i] * scale;\n }\n return out;\n}\n\nexport function prod(array: ArrayLike) {\n let result = 1;\n for (let i = 0, length = array.length; i < length; ++i) {\n result *= array[i];\n }\n return result;\n}\n\nexport function min<\n Out extends TypedArray,\n A extends TypedArray,\n B extends TypedArray,\n>(out: Out, a: A, b: B) {\n const rank = out.length;\n for (let i = 0; i < rank; ++i) {\n out[i] = Math.min(a[i], b[i]);\n }\n return out;\n}\n\nexport function max<\n Out extends TypedArray,\n A extends TypedArray,\n B extends TypedArray,\n>(out: Out, a: A, b: B) {\n const rank = out.length;\n for (let i = 0; i < rank; ++i) {\n out[i] = Math.max(a[i], b[i]);\n }\n return out;\n}\n\nexport const kEmptyFloat32Vec = new Float32Array(0);\nexport const kEmptyFloat64Vec = new Float64Array(0);\nexport const kFloat64Vec3Of1 = Float64Array.of(1, 1, 1);\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { WatchableValue } from \"#src/trackable_value.js\";\nimport type { TypedArray } from \"#src/util/array.js\";\nimport {\n arraysEqual,\n arraysEqualWithPredicate,\n getInsertPermutation,\n} from \"#src/util/array.js\";\nimport {\n getDependentTransformInputDimensions,\n mat4,\n quat,\n vec3,\n} from \"#src/util/geom.js\";\nimport {\n expectArray,\n parseArray,\n parseFiniteVec,\n parseFixedLengthArray,\n verifyFiniteFloat,\n verifyFinitePositiveFloat,\n verifyIntegerArray,\n verifyObject,\n verifyObjectProperty,\n verifyOptionalObjectProperty,\n verifyString,\n verifyStringArray,\n} from \"#src/util/json.js\";\nimport * as matrix from \"#src/util/matrix.js\";\nimport {\n scaleByExp10,\n supportedUnits,\n unitFromJson,\n} from \"#src/util/si_units.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport type { Trackable } from \"#src/util/trackable.js\";\nimport * as vector from \"#src/util/vector.js\";\n\nexport type DimensionId = number;\n\nlet nextDimensionId = 0;\n\nexport function newDimensionId(): DimensionId {\n return ++nextDimensionId;\n}\n\nexport interface CoordinateArray {\n // Indicates whether this coordinate array was specified explicitly, in which case it will be\n // encoded in the JSON representation.\n explicit: boolean;\n // Specifies the coordinates. Must be montonically increasing integers.\n coordinates: number[];\n // Specifies the label for each coordinate in `coordinates`.\n labels: string[];\n}\n\nexport interface CoordinateSpace {\n /**\n * If `true`, has been fully initialized (i.e. based on at least one data source). If `false`,\n * may be partially initialized.\n */\n readonly valid: boolean;\n\n readonly rank: number;\n\n /**\n * Specifies the name of each dimension.\n */\n readonly names: readonly string[];\n\n readonly ids: readonly DimensionId[];\n\n /**\n * Timestamp of last user action that changed the name, scale, or unit of each dimension, or\n * `undefined` if there was no user action.\n */\n readonly timestamps: readonly number[];\n\n /**\n * Specifies the physical units corresponding to this dimension. May be empty to indicate\n * unitless.\n */\n readonly units: readonly string[];\n\n /**\n * Specifies a scale for this dimension.\n */\n readonly scales: Float64Array;\n\n readonly bounds: CoordinateSpaceBounds;\n readonly boundingBoxes: readonly TransformedBoundingBox[];\n\n readonly coordinateArrays: (CoordinateArray | undefined)[];\n}\n\nexport function boundingBoxesEqual(a: BoundingBox, b: BoundingBox) {\n return (\n arraysEqual(a.lowerBounds, b.lowerBounds) &&\n arraysEqual(a.upperBounds, b.upperBounds)\n );\n}\n\nexport function coordinateArraysEqual(\n a: CoordinateArray | undefined,\n b: CoordinateArray | undefined,\n) {\n if (a === undefined) return b === undefined;\n if (b === undefined) return false;\n return (\n a.explicit === b.explicit &&\n arraysEqual(a.coordinates, b.coordinates) &&\n arraysEqual(a.labels, b.labels)\n );\n}\n\nexport function normalizeCoordinateArray(\n coordinates: number[],\n labels: string[],\n) {\n const map = new Map();\n for (let i = 0, length = coordinates.length; i < length; ++i) {\n map.set(coordinates[i], labels[i]);\n }\n coordinates = Array.from(map.keys());\n coordinates.sort((a, b) => a - b);\n labels = Array.from(coordinates, (x) => map.get(x)!);\n return { coordinates, labels };\n}\n\nexport function mergeCoordinateArrays(\n coordinateArrays: ReadonlyArray,\n): CoordinateArray {\n if (coordinateArrays.length === 1) return coordinateArrays[0];\n const map = new Map();\n let explicit = false;\n for (const x of coordinateArrays) {\n if (x.explicit) explicit = true;\n const { coordinates, labels } = x;\n for (let i = 0, length = coordinates.length; i < length; ++i) {\n map.set(coordinates[i], labels[i]);\n }\n }\n const coordinates = Array.from(map.keys());\n coordinates.sort((a, b) => a - b);\n const labels = Array.from(coordinates, (x) => map.get(x)!);\n return { explicit, coordinates, labels };\n}\n\nexport function mergeOptionalCoordinateArrays(\n coordinateArrays: ReadonlyArray,\n): CoordinateArray | undefined {\n coordinateArrays = coordinateArrays.filter((x) => x !== undefined);\n if (coordinateArrays.length === 0) return undefined;\n return mergeCoordinateArrays(\n coordinateArrays as ReadonlyArray,\n );\n}\n\nexport function transformedBoundingBoxesEqual(\n a: TransformedBoundingBox,\n b: TransformedBoundingBox,\n) {\n return (\n arraysEqual(a.transform, b.transform) && boundingBoxesEqual(a.box, b.box)\n );\n}\n\nexport function coordinateSpacesEqual(a: CoordinateSpace, b: CoordinateSpace) {\n return (\n a.valid === b.valid &&\n a.rank === b.rank &&\n arraysEqual(a.names, b.names) &&\n arraysEqual(a.ids, b.ids) &&\n arraysEqual(a.timestamps, b.timestamps) &&\n arraysEqual(a.units, b.units) &&\n arraysEqual(a.scales, b.scales) &&\n arraysEqualWithPredicate(\n a.boundingBoxes,\n b.boundingBoxes,\n transformedBoundingBoxesEqual,\n ) &&\n arraysEqualWithPredicate(\n a.coordinateArrays,\n b.coordinateArrays,\n coordinateArraysEqual,\n )\n );\n}\n\nexport function unitsFromJson(\n units: string[],\n scaleExponents: Float64Array,\n obj: any,\n) {\n parseFixedLengthArray(units, obj, (x: any, index: number) => {\n const result = unitFromJson(x);\n scaleExponents[index] = result.exponent;\n return result.unit;\n });\n}\n\nexport function makeCoordinateSpace(space: {\n readonly valid?: boolean;\n readonly names: readonly string[];\n readonly units: readonly string[];\n readonly scales: Float64Array;\n readonly rank?: number;\n readonly timestamps?: readonly number[];\n readonly ids?: readonly DimensionId[];\n readonly boundingBoxes?: readonly TransformedBoundingBox[];\n readonly bounds?: CoordinateSpaceBounds;\n readonly coordinateArrays?: (CoordinateArray | undefined)[];\n}): CoordinateSpace {\n const { names, units, scales } = space;\n const {\n valid = true,\n rank = names.length,\n timestamps = names.map(() => Number.NEGATIVE_INFINITY),\n ids = names.map((_, i) => -i),\n boundingBoxes = [],\n } = space;\n const { coordinateArrays = new Array(rank) } =\n space;\n const { bounds = computeCombinedBounds(boundingBoxes, rank) } = space;\n return {\n valid,\n rank,\n names,\n timestamps,\n ids,\n units,\n scales,\n boundingBoxes,\n bounds,\n coordinateArrays,\n };\n}\n\nexport const emptyInvalidCoordinateSpace = makeCoordinateSpace({\n valid: false,\n names: [],\n units: [],\n scales: vector.kEmptyFloat64Vec,\n boundingBoxes: [],\n});\n\nexport const emptyValidCoordinateSpace = makeCoordinateSpace({\n valid: true,\n names: [],\n units: [],\n scales: vector.kEmptyFloat64Vec,\n boundingBoxes: [],\n});\n\nfunction unitAndScaleFromJson(obj: unknown) {\n const [scaleObj, unitObj] = expectArray(obj, 2);\n const scale = verifyFinitePositiveFloat(scaleObj);\n const unitString = verifyString(unitObj);\n const result = supportedUnits.get(unitString);\n if (result === undefined)\n throw new Error(`Invalid unit: ${JSON.stringify(unitString)}`);\n return { unit: result.unit, scale: scaleByExp10(scale, result.exponent) };\n}\n\nexport function coordinateSpaceFromJson(\n obj: any,\n allowNumericalDimensions = false,\n): CoordinateSpace {\n if (obj === undefined) return emptyInvalidCoordinateSpace;\n verifyObject(obj);\n const names = dimensionNamesFromJson(\n Object.keys(obj),\n allowNumericalDimensions,\n );\n const rank = names.length;\n const units = new Array(rank);\n const scales = new Float64Array(rank);\n const coordinateArrays = new Array(rank);\n for (let i = 0; i < rank; ++i) {\n verifyObjectProperty(obj, names[i], (mem) => {\n if (Array.isArray(mem)) {\n // Normal unit-scale dimension.\n const { unit, scale } = unitAndScaleFromJson(mem);\n units[i] = unit;\n scales[i] = scale;\n } else {\n // Coordinate array dimension.\n verifyObject(mem);\n const coordinates = verifyObjectProperty(\n mem,\n \"coordinates\",\n verifyIntegerArray,\n );\n const labels = verifyObjectProperty(mem, \"labels\", verifyStringArray);\n const length = coordinates.length;\n if (length !== labels.length) {\n throw new Error(\n `Length of coordinates array (${length}) ` +\n `does not match length of labels array (${labels.length})`,\n );\n }\n units[i] = \"\";\n scales[i] = 1;\n coordinateArrays[i] = {\n explicit: true,\n ...normalizeCoordinateArray(coordinates, labels),\n };\n }\n });\n }\n return makeCoordinateSpace({\n valid: false,\n names,\n units,\n scales,\n coordinateArrays,\n });\n}\n\nexport function coordinateSpaceToJson(coordinateSpace: CoordinateSpace): any {\n const { rank } = coordinateSpace;\n if (rank === 0) return undefined;\n const { names, units, scales, coordinateArrays } = coordinateSpace;\n const json: any = {};\n for (let i = 0; i < rank; ++i) {\n const name = names[i];\n const coordinateArray = coordinateArrays[i];\n if (coordinateArray?.explicit) {\n json[name] = {\n coordinates: Array.from(coordinateArray.coordinates),\n labels: coordinateArray.labels,\n };\n } else {\n json[name] = [scales[i], units[i]];\n }\n }\n return json;\n}\n\nexport class TrackableCoordinateSpace extends WatchableValue {\n constructor() {\n super(emptyInvalidCoordinateSpace);\n }\n\n toJSON() {\n return coordinateSpaceToJson(this.value);\n }\n reset() {\n this.value = emptyInvalidCoordinateSpace;\n }\n restoreState(obj: any) {\n this.value = coordinateSpaceFromJson(obj);\n }\n}\n\nexport interface BoundingBox {\n lowerBounds: Float64Array;\n upperBounds: Float64Array;\n}\n\nexport interface CoordinateSpaceBounds extends BoundingBox {\n voxelCenterAtIntegerCoordinates: boolean[];\n}\n\nexport function roundCoordinateToVoxelCenter(\n bounds: CoordinateSpaceBounds,\n dimIndex: number,\n coordinate: number,\n) {\n if (bounds.voxelCenterAtIntegerCoordinates[dimIndex]) {\n coordinate = Math.round(coordinate);\n } else {\n coordinate = Math.floor(coordinate) + 0.5;\n }\n return coordinate;\n}\n\nexport function getDisplayLowerUpperBounds(\n bounds: CoordinateSpaceBounds,\n dimIndex: number,\n) {\n let lower = bounds.lowerBounds[dimIndex];\n let upper = bounds.upperBounds[dimIndex];\n if (bounds.voxelCenterAtIntegerCoordinates[dimIndex]) {\n lower += 0.5;\n upper += 0.5;\n }\n return [lower, upper];\n}\n\n// Clamps `coordinate` to `[lower, upper - 1]`. This is intended to be used with\n// `roundCoordinateToVoxelCenter`. If not rounding, it may be desirable to instead\n// clamp to `[lower upper]`.\nexport function clampCoordinateToBounds(\n bounds: CoordinateSpaceBounds,\n dimIndex: number,\n coordinate: number,\n) {\n const upperBound = bounds.upperBounds[dimIndex];\n if (Number.isFinite(upperBound)) {\n coordinate = Math.min(coordinate, upperBound - 1);\n }\n\n const lowerBound = bounds.lowerBounds[dimIndex];\n if (Number.isFinite(lowerBound)) {\n coordinate = Math.max(coordinate, lowerBound);\n }\n return coordinate;\n}\n\nexport function clampAndRoundCoordinateToVoxelCenter(\n bounds: CoordinateSpaceBounds,\n dimIndex: number,\n coordinate: number,\n): number {\n coordinate = clampCoordinateToBounds(bounds, dimIndex, coordinate);\n return roundCoordinateToVoxelCenter(bounds, dimIndex, coordinate);\n}\n\nexport function getCenterBound(lower: number, upper: number) {\n let x = (lower + upper) / 2;\n if (!Number.isFinite(x)) x = Math.min(Math.max(0, lower), upper);\n return x;\n}\n\nexport function getBoundingBoxCenter(\n out: Float32Array,\n bounds: BoundingBox,\n): Float32Array {\n const { lowerBounds, upperBounds } = bounds;\n const rank = out.length;\n for (let i = 0; i < rank; ++i) {\n out[i] = getCenterBound(lowerBounds[i], upperBounds[i]);\n }\n return out;\n}\n\nexport interface TransformedBoundingBox {\n box: BoundingBox;\n\n /**\n * Transform from \"box\" coordinate space to target coordinate space.\n */\n transform: Float64Array;\n}\n\nexport function makeIdentityTransformedBoundingBox(box: BoundingBox) {\n const rank = box.lowerBounds.length;\n return {\n box,\n transform: matrix.createIdentity(Float64Array, rank, rank + 1),\n };\n}\n\nexport function computeCombinedLowerUpperBound(\n boundingBox: TransformedBoundingBox,\n outputDimension: number,\n outputRank: number,\n): { lower: number; upper: number } | undefined {\n const {\n box: { lowerBounds: baseLowerBounds, upperBounds: baseUpperBounds },\n transform,\n } = boundingBox;\n const inputRank = baseLowerBounds.length;\n const stride = outputRank;\n const offset = transform[stride * inputRank + outputDimension];\n let targetLower = offset;\n let targetUpper = offset;\n let hasCoefficient = false;\n for (let inputDim = 0; inputDim < inputRank; ++inputDim) {\n const c = transform[stride * inputDim + outputDimension];\n if (c === 0) continue;\n const lower = c * baseLowerBounds[inputDim];\n const upper = c * baseUpperBounds[inputDim];\n targetLower += Math.min(lower, upper);\n targetUpper += Math.max(lower, upper);\n hasCoefficient = true;\n }\n if (!hasCoefficient) return undefined;\n return { lower: targetLower, upper: targetUpper };\n}\n\nexport function computeCombinedBounds(\n boundingBoxes: readonly TransformedBoundingBox[],\n outputRank: number,\n): CoordinateSpaceBounds {\n const lowerBounds = new Float64Array(outputRank);\n const upperBounds = new Float64Array(outputRank);\n lowerBounds.fill(Number.NEGATIVE_INFINITY);\n upperBounds.fill(Number.POSITIVE_INFINITY);\n\n // Number of bounding boxes for which both lower and upper bound has a fractional part of `0.5`.\n const halfIntegerBounds = new Array(outputRank);\n halfIntegerBounds.fill(0);\n\n // Number of bounding boxes for which both lower and upper bound has a fractional part of `0.0`.\n const integerBounds = new Array(outputRank);\n integerBounds.fill(0);\n\n for (const boundingBox of boundingBoxes) {\n for (let outputDim = 0; outputDim < outputRank; ++outputDim) {\n const result = computeCombinedLowerUpperBound(\n boundingBox,\n outputDim,\n outputRank,\n );\n if (result === undefined) continue;\n const { lower: targetLower, upper: targetUpper } = result;\n if (Number.isFinite(targetLower) && Number.isFinite(targetUpper)) {\n const lowerFloor = Math.floor(targetLower);\n const upperFloor = Math.floor(targetUpper);\n if (lowerFloor === targetLower && upperFloor === targetUpper) {\n ++integerBounds[outputDim];\n } else if (\n targetLower - lowerFloor === 0.5 &&\n targetUpper - upperFloor === 0.5\n ) {\n ++halfIntegerBounds[outputDim];\n }\n }\n lowerBounds[outputDim] =\n lowerBounds[outputDim] === Number.NEGATIVE_INFINITY\n ? targetLower\n : Math.min(lowerBounds[outputDim], targetLower);\n upperBounds[outputDim] =\n upperBounds[outputDim] === Number.POSITIVE_INFINITY\n ? targetUpper\n : Math.max(upperBounds[outputDim], targetUpper);\n }\n }\n\n const voxelCenterAtIntegerCoordinates = integerBounds.map(\n (integerCount, i) => {\n const halfIntegerCount = halfIntegerBounds[i];\n // If all bounding boxes have half-integer bounds, assume voxel center is at integer\n // coordinates. Otherwise, assume voxel center is at half-integer coordinates.\n return halfIntegerCount > 0 && integerCount === 0;\n },\n );\n return { lowerBounds, upperBounds, voxelCenterAtIntegerCoordinates };\n}\n\nexport function extendTransformedBoundingBox(\n boundingBox: TransformedBoundingBox,\n newOutputRank: number,\n newOutputDims: readonly number[],\n): TransformedBoundingBox {\n const { transform: oldTransform, box } = boundingBox;\n const oldOutputRank = newOutputDims.length;\n const inputRank = box.lowerBounds.length;\n const newTransform = new Float64Array((inputRank + 1) * newOutputRank);\n for (let oldOutputDim = 0; oldOutputDim < oldOutputRank; ++oldOutputDim) {\n const newOutputDim = newOutputDims[oldOutputDim];\n if (newOutputDim === -1) continue;\n for (let inputDim = 0; inputDim <= inputRank; ++inputDim) {\n newTransform[inputDim * newOutputRank + newOutputDim] =\n oldTransform[inputDim * oldOutputRank + oldOutputDim];\n }\n }\n return {\n transform: newTransform,\n box,\n };\n}\n\nexport function makeSingletonDimTransformedBoundingBox(\n outputRank: number,\n outputDim: number,\n) {\n const box = {\n lowerBounds: Float64Array.of(0),\n upperBounds: Float64Array.of(1),\n };\n const transform = new Float64Array(2 * outputRank);\n transform[outputDim] = 1;\n return { transform, box };\n}\n\nexport function extendTransformedBoundingBoxUpToRank(\n boundingBox: TransformedBoundingBox,\n oldOutputRank: number,\n newOutputRank: number,\n): TransformedBoundingBox {\n if (oldOutputRank === newOutputRank) return boundingBox;\n const { box } = boundingBox;\n const inputRank = box.lowerBounds.length;\n const transform = new Float64Array((inputRank + 1) * newOutputRank);\n matrix.copy(\n transform,\n newOutputRank,\n boundingBox.transform,\n oldOutputRank,\n oldOutputRank,\n inputRank + 1,\n );\n return { box, transform };\n}\n\nexport interface CoordinateSpaceTransform {\n /**\n * Equal to `outputSpace.rank`.\n */\n readonly rank: number;\n\n /**\n * The source rank, which is <= rank. Input dimensions >= sourceRank are synthetic and serve only\n * to embed the source data in a larger view space.\n */\n readonly sourceRank: number;\n\n /**\n * May have rank less than `outputSpace.rank`, in which case additional unnamed dimensions with\n * range `[0, 1)` are implicitly added.\n */\n readonly inputSpace: CoordinateSpace;\n\n readonly outputSpace: CoordinateSpace;\n\n /**\n * `(rank + 1) * (rank + 1)` homogeneous column-major transformation matrix, where columns\n * correspond to input dimensions and rows correspond to output dimensions.\n */\n readonly transform: Float64Array;\n}\n\nexport function coordinateSpaceTransformsEquivalent(\n defaultTransform: CoordinateSpaceTransform,\n transform: CoordinateSpaceTransform,\n) {\n const { rank, sourceRank } = defaultTransform;\n if (rank !== transform.rank || sourceRank !== transform.sourceRank)\n return false;\n const { inputSpace: defaultInputSpace } = defaultTransform;\n const { inputSpace } = transform;\n if (\n !arraysEqual(inputSpace.scales, defaultInputSpace.scales) ||\n !arraysEqual(inputSpace.units, defaultInputSpace.units) ||\n !arraysEqual(\n transform.outputSpace.names,\n defaultTransform.outputSpace.names,\n )\n ) {\n return false;\n }\n return isTransformDerivableFromDefault(\n defaultTransform.transform,\n rank,\n defaultTransform.outputSpace.scales,\n transform.transform,\n rank,\n transform.outputSpace.scales,\n );\n}\n\nexport function makeIdentityTransform(\n inputSpace: CoordinateSpace,\n): CoordinateSpaceTransform {\n return {\n rank: inputSpace.rank,\n sourceRank: inputSpace.rank,\n inputSpace,\n outputSpace: inputSpace,\n transform: matrix.createIdentity(Float64Array, inputSpace.rank + 1),\n };\n}\n\nfunction transformBoundingBox(\n boundingBox: TransformedBoundingBox,\n transform: Float64Array,\n sourceScales: Float64Array,\n targetScales: Float64Array,\n): TransformedBoundingBox {\n const { transform: oldBoxTransform, box } = boundingBox;\n const inputRank = boundingBox.box.lowerBounds.length;\n const targetRank = targetScales.length;\n // transform is a column-major homogeneous `(rows=targetRank+1, cols=targetRank+1)` matrix.\n // oldBoxTransform is a column-major `(rows=targetRank, cols=inputRank+1)` matrix.\n // newBoxTransform is a column-major `(rows=targetRank, cols=inputRank+1)` matrix.\n const newBoxTransform = new Float64Array((inputRank + 1) * targetRank);\n for (let targetDim = 0; targetDim < targetRank; ++targetDim) {\n const targetScale = targetScales[targetDim];\n // Compute the rotation/scaling components\n for (let inputDim = 0; inputDim < inputRank; ++inputDim) {\n let sum = 0;\n for (let sourceDim = 0; sourceDim < targetRank; ++sourceDim) {\n const sourceScale = sourceScales[sourceDim];\n sum +=\n transform[(targetRank + 1) * sourceDim + targetDim] *\n oldBoxTransform[targetRank * inputDim + sourceDim] *\n (sourceScale / targetScale);\n }\n newBoxTransform[targetRank * inputDim + targetDim] = sum;\n }\n // Compute the translation component\n let sum = transform[(targetRank + 1) * targetRank + targetDim];\n for (let sourceDim = 0; sourceDim < targetRank; ++sourceDim) {\n const sourceScale = sourceScales[sourceDim];\n sum +=\n transform[(targetRank + 1) * sourceDim + targetDim] *\n oldBoxTransform[targetRank * inputRank + sourceDim] *\n (sourceScale / targetScale);\n }\n newBoxTransform[inputRank * targetRank + targetDim] = sum;\n }\n return {\n transform: newBoxTransform,\n box,\n };\n}\n\nfunction getTransformedBoundingBoxes(\n inputSpace: CoordinateSpace,\n transform: Float64Array,\n outputScales: Float64Array,\n) {\n return inputSpace.boundingBoxes.map((boundingBox) =>\n transformBoundingBox(\n boundingBox,\n transform,\n inputSpace.scales,\n outputScales,\n ),\n );\n}\n\nexport function getOutputSpaceWithTransformedBoundingBoxes(\n inputSpace: CoordinateSpace,\n transform: Float64Array,\n oldOutputSpace: CoordinateSpace,\n) {\n const newSpace = makeCoordinateSpace({\n valid: inputSpace.valid,\n rank: oldOutputSpace.rank,\n ids: oldOutputSpace.ids,\n names: oldOutputSpace.names,\n timestamps: oldOutputSpace.timestamps,\n scales: oldOutputSpace.scales,\n units: oldOutputSpace.units,\n boundingBoxes: getTransformedBoundingBoxes(\n inputSpace,\n transform,\n oldOutputSpace.scales,\n ),\n coordinateArrays: oldOutputSpace.coordinateArrays,\n });\n if (coordinateSpacesEqual(newSpace, oldOutputSpace)) return oldOutputSpace;\n return newSpace;\n}\n\nexport function isValidDimensionName(\n name: string,\n allowNumericalNames = false,\n) {\n if (allowNumericalNames) {\n const n = Number(name);\n if (Number.isInteger(n) && n >= 0) return true;\n }\n return name.match(/^[a-zA-Z][a-zA-Z_0-9]*['^]?$/) !== null;\n}\n\nexport function validateDimensionNames(\n names: string[],\n allowNumericalNames = false,\n) {\n const seenNames = new Set();\n for (const name of names) {\n if (!isValidDimensionName(name, allowNumericalNames)) return false;\n if (seenNames.has(name)) return false;\n seenNames.add(name);\n }\n return true;\n}\n\nexport function getDimensionNameValidity(names: readonly string[]): boolean[] {\n const rank = names.length;\n const isValid = new Array(rank);\n isValid.fill(true);\n for (let i = 0; i < rank; ++i) {\n const name = names[i];\n if (!isValidDimensionName(name)) {\n isValid[i] = false;\n continue;\n }\n const otherIndex = names.indexOf(name, i + 1);\n if (otherIndex !== -1) {\n isValid[i] = false;\n isValid[otherIndex] = false;\n }\n }\n return isValid;\n}\n\nexport function isLocalDimension(name: string) {\n return name.endsWith(\"'\");\n}\n\nexport function isLocalOrChannelDimension(name: string) {\n return name.endsWith(\"'\") || name.endsWith(\"^\");\n}\n\nexport function isChannelDimension(name: string) {\n return name.endsWith(\"^\");\n}\n\nexport function isGlobalDimension(name: string) {\n return !isLocalOrChannelDimension(name);\n}\n\nexport function convertTransformOutputScales(\n existingTransform: Float64Array,\n existingOutputScales: Float64Array,\n newOutputScales: Float64Array,\n) {\n const newTransform = new Float64Array(existingTransform);\n const rank = existingOutputScales.length;\n const baseIndex = (rank + 1) * rank;\n for (let i = 0; i < rank; ++i) {\n newTransform[baseIndex + i] *= existingOutputScales[i] / newOutputScales[i];\n }\n return newTransform;\n}\n\nfunction isTransformDerivableFromDefault(\n defaultTransform: Float64Array,\n defaultRank: number,\n defaultOutputScales: Float64Array,\n newTransform: Float64Array,\n newRank: number,\n newOutputScales: Float64Array,\n) {\n // Verify that matched linear portion is equal.\n if (\n !matrix.equal(\n defaultTransform,\n defaultRank + 1,\n newTransform,\n newRank + 1,\n defaultRank,\n defaultRank,\n )\n )\n return false;\n\n // Verify that common translation is equivalent.\n for (let i = 0; i < defaultRank; ++i) {\n const aValue = defaultTransform[(defaultRank + 1) * defaultRank + i];\n const bValue = newTransform[(newRank + 1) * newRank + i];\n if (aValue * (defaultOutputScales[i] / newOutputScales[i]) !== bValue)\n return false;\n }\n\n // Verify that extended translation is 0.\n for (let i = defaultRank; i < newRank; ++i) {\n if (newTransform[(newRank + 1) * newRank + i] !== 0) return false;\n }\n\n // Verify that extended linear portion is identity.\n for (let i = defaultRank; i < newRank; ++i) {\n for (let j = 0; j < defaultRank; ++j) {\n if (newTransform[(newRank + 1) * j + i] !== 0) return false;\n }\n for (let j = 0; j < newRank; ++j) {\n const coeff = newTransform[(newRank + 1) * i + j];\n if (i === j) {\n if (coeff !== 1) return false;\n } else {\n if (coeff !== 0) return false;\n }\n }\n }\n return true;\n}\n\nexport function makeDimensionNameUnique(\n name: string,\n existingNames: readonly string[],\n) {\n if (!existingNames.includes(name)) return name;\n const [, prefix, suffix] = name.match(/^([^']*)('?)$/)!;\n for (let i = 0; ; ++i) {\n const newName = `${prefix}${i}${suffix}`;\n if (!existingNames.includes(newName)) return newName;\n }\n}\n\nexport function remapTransformInputSpace(\n old: CoordinateSpaceTransform,\n inputSpace: CoordinateSpace,\n): CoordinateSpaceTransform {\n const { inputSpace: oldInputSpace, transform: oldTransform } = old;\n const { ids: oldInputDimensionIds, rank: oldRank } = oldInputSpace;\n const {\n rank: newRank,\n names: newInputDimensionNames,\n units: newInputUnits,\n scales: newInputScales,\n } = inputSpace;\n const removedOldInputIndices = new Array(oldRank);\n removedOldInputIndices.fill(true);\n const addedInputDimensionIndices: number[] = [];\n const newToOldInputDimensionIndices: number[] = inputSpace.ids.map(\n (id, i) => {\n const oldIndex = oldInputDimensionIds.indexOf(id);\n if (oldIndex !== -1) {\n removedOldInputIndices[oldIndex] = false;\n } else {\n addedInputDimensionIndices.push(i);\n }\n return oldIndex;\n },\n );\n const { outputSpace: oldOutputSpace } = old;\n const {\n names: oldOutputDimensionNames,\n units: oldOutputUnits,\n scales: oldOutputScales,\n ids: oldOutputDimensionIds,\n timestamps: oldOutputTimestamps,\n coordinateArrays: oldOutputCoordinateArrays,\n } = oldOutputSpace;\n // For now just use a simple mapping.\n const removedOldOutputIndices = removedOldInputIndices;\n const outputDimensionNames: string[] = [];\n const outputUnits: string[] = [];\n const outputScales = new Float64Array(newRank);\n const outputDimensionIds: DimensionId[] = [];\n const outputDimensionTimestamps: number[] = [];\n const outputCoordinateArrays = new Array(\n newRank,\n );\n let newOutputDim = 0;\n const newTransform = new Float64Array((newRank + 1) ** 2);\n newTransform[newTransform.length - 1] = 1;\n for (let oldOutputDim = 0; oldOutputDim < oldRank; ++oldOutputDim) {\n if (removedOldOutputIndices[oldOutputDim]) continue;\n outputDimensionNames[newOutputDim] = oldOutputDimensionNames[oldOutputDim];\n outputDimensionIds[newOutputDim] = oldOutputDimensionIds[oldOutputDim];\n outputUnits[newOutputDim] = oldOutputUnits[oldOutputDim];\n outputScales[newOutputDim] = oldOutputScales[oldOutputDim];\n outputDimensionTimestamps[newOutputDim] = oldOutputTimestamps[oldOutputDim];\n outputCoordinateArrays[newOutputDim] =\n oldOutputCoordinateArrays[oldOutputDim];\n for (let newInputDim = 0; newInputDim < newRank; ++newInputDim) {\n const oldInputDim = newToOldInputDimensionIndices[newInputDim];\n if (oldInputDim === -1) continue;\n newTransform[newInputDim * (newRank + 1) + newOutputDim] =\n oldTransform[oldInputDim * (oldRank + 1) + oldOutputDim];\n }\n newTransform[newRank * (newRank + 1) + newOutputDim] =\n oldTransform[oldRank * (oldRank + 1) + oldOutputDim];\n ++newOutputDim;\n }\n for (const newInputDim of addedInputDimensionIndices) {\n outputDimensionIds[newOutputDim] = newDimensionId();\n outputDimensionNames[newOutputDim] = makeDimensionNameUnique(\n newInputDimensionNames[newInputDim],\n outputDimensionNames,\n );\n outputScales[newOutputDim] = newInputScales[newInputDim];\n outputUnits[newOutputDim] = newInputUnits[newInputDim];\n newTransform[newInputDim * (newRank + 1) + newOutputDim] = 1;\n ++newOutputDim;\n }\n const outputSpace = makeCoordinateSpace({\n valid: inputSpace.valid,\n rank: newRank,\n names: outputDimensionNames,\n ids: outputDimensionIds,\n timestamps: outputDimensionTimestamps,\n units: outputUnits,\n scales: outputScales,\n boundingBoxes: getTransformedBoundingBoxes(\n inputSpace,\n newTransform,\n outputScales,\n ),\n coordinateArrays: outputCoordinateArrays,\n });\n return {\n rank: newRank,\n sourceRank: old.sourceRank,\n inputSpace,\n outputSpace,\n transform: newTransform,\n };\n}\n\nfunction normalizeCoordinateSpaceTransform(value: CoordinateSpaceTransform) {\n const outputSpace = getOutputSpaceWithTransformedBoundingBoxes(\n value.inputSpace,\n value.transform,\n value.outputSpace,\n );\n if (outputSpace === value.outputSpace) return value;\n return {\n rank: value.rank,\n sourceRank: value.sourceRank,\n inputSpace: value.inputSpace,\n transform: value.transform,\n outputSpace,\n };\n}\n\nexport class WatchableCoordinateSpaceTransform\n implements Trackable, WatchableValueInterface\n{\n private value_: CoordinateSpaceTransform | undefined = undefined;\n readonly outputSpace: WatchableValueInterface;\n readonly inputSpace: WatchableValueInterface;\n changed = new NullarySignal();\n private inputSpaceChanged = new NullarySignal();\n readonly defaultTransform: CoordinateSpaceTransform;\n\n constructor(\n defaultTransform: CoordinateSpaceTransform,\n public readonly mutableSourceRank: boolean = false,\n ) {\n this.defaultTransform = normalizeCoordinateSpaceTransform(defaultTransform);\n const self = this;\n this.outputSpace = {\n changed: self.changed,\n get value() {\n return self.value.outputSpace;\n },\n set value(newOutputSpace: CoordinateSpace) {\n const { value } = self;\n if (coordinateSpacesEqual(value.outputSpace, newOutputSpace)) return;\n if (value.rank !== newOutputSpace.rank) return;\n const transform = convertTransformOutputScales(\n value.transform,\n value.outputSpace.scales,\n newOutputSpace.scales,\n );\n self.value_ = {\n sourceRank: value.sourceRank,\n rank: value.rank,\n inputSpace: value.inputSpace,\n outputSpace: getOutputSpaceWithTransformedBoundingBoxes(\n value.inputSpace,\n transform,\n newOutputSpace,\n ),\n transform,\n };\n self.changed.dispatch();\n },\n };\n this.inputSpace = {\n changed: self.inputSpaceChanged,\n get value() {\n return self.value.inputSpace;\n },\n set value(newInputSpace: CoordinateSpace) {\n const { value } = self;\n if (coordinateSpacesEqual(value.inputSpace, newInputSpace)) return;\n self.value_ = remapTransformInputSpace(value, newInputSpace);\n self.inputSpaceChanged.dispatch();\n self.changed.dispatch();\n },\n };\n }\n\n set value(value: CoordinateSpaceTransform) {\n const existingValue = this.value;\n if (value === existingValue) return;\n this.value_ = normalizeCoordinateSpaceTransform(value);\n if (value.inputSpace !== existingValue.inputSpace) {\n this.inputSpaceChanged.dispatch();\n }\n this.changed.dispatch();\n }\n\n get value(): CoordinateSpaceTransform {\n let { value_: value } = this;\n if (value === undefined) {\n value = this.value_ = this.defaultTransform;\n }\n return value;\n }\n\n reset() {\n if (this.value_ === this.defaultTransform) return;\n this.value_ = this.defaultTransform;\n this.inputSpaceChanged.dispatch();\n this.changed.dispatch();\n }\n\n get defaultInputSpace() {\n return this.defaultTransform.inputSpace;\n }\n\n get spec(): Readonly | undefined {\n const { value } = this;\n const { rank, transform, inputSpace, outputSpace, sourceRank } = value;\n const { defaultTransform, mutableSourceRank } = this;\n const {\n inputSpace: defaultInputSpace,\n rank: defaultRank,\n transform: defaultTransformMatrix,\n outputSpace: defaultOutputSpace,\n } = defaultTransform;\n const { units, scales } = inputSpace;\n const inputSpaceSame =\n sourceRank === rank &&\n arraysEqual(\n scales,\n mutableSourceRank ? outputSpace.scales : defaultInputSpace.scales,\n ) &&\n arraysEqual(\n units,\n mutableSourceRank ? outputSpace.units : defaultInputSpace.units,\n );\n const transformSame = isTransformDerivableFromDefault(\n defaultTransformMatrix,\n defaultRank,\n defaultOutputSpace.scales,\n transform,\n rank,\n outputSpace.scales,\n );\n const outputNamesSame = arraysEqual(\n defaultOutputSpace.names,\n outputSpace.names,\n );\n if (transformSame && outputNamesSame && inputSpaceSame) {\n return undefined;\n }\n return {\n sourceRank,\n transform: transformSame ? undefined : transform,\n outputSpace: value.outputSpace,\n inputSpace: inputSpaceSame ? undefined : inputSpace,\n };\n }\n\n set transform(transform: Float64Array) {\n const { value } = this;\n const { inputSpace } = value;\n this.value_ = {\n rank: value.rank,\n sourceRank: value.sourceRank,\n inputSpace,\n transform,\n outputSpace: getOutputSpaceWithTransformedBoundingBoxes(\n inputSpace,\n transform,\n value.outputSpace,\n ),\n };\n this.changed.dispatch();\n }\n\n set spec(spec: Readonly | undefined) {\n if (spec === undefined) {\n this.reset();\n return;\n }\n if (this.mutableSourceRank) {\n const origInputSpace = spec.inputSpace || spec.outputSpace;\n const rank = origInputSpace.rank;\n const inputSpace = makeCoordinateSpace({\n rank,\n names: origInputSpace.names.map((_, i) => `${i}`),\n units: origInputSpace.units,\n scales: origInputSpace.scales,\n coordinateArrays: origInputSpace.coordinateArrays,\n });\n this.value = {\n rank,\n transform:\n spec.transform || matrix.createIdentity(Float64Array, rank + 1),\n sourceRank: spec.sourceRank,\n outputSpace: spec.outputSpace,\n inputSpace,\n };\n return;\n }\n const {\n inputSpace: defaultInputSpace,\n sourceRank: defaultSourceRank,\n outputSpace: defaultOutputSpace,\n transform: defaultTransformMatrix,\n rank: defaultRank,\n } = this.defaultTransform;\n const {\n inputSpace: specInputSpace,\n sourceRank: specSourceRank,\n outputSpace: specOutputSpace,\n transform: specTransformMatrix,\n } = spec;\n const specRank = spec.outputSpace.rank;\n const defaultInputNames = defaultInputSpace.names;\n const specInputNames =\n specInputSpace !== undefined ? specInputSpace.names : defaultInputNames;\n const newToSpecDimensionIndices = new Array(defaultSourceRank);\n for (let defaultDim = 0; defaultDim < defaultSourceRank; ++defaultDim) {\n let specDim = specInputNames.indexOf(defaultInputNames[defaultDim]);\n if (specDim >= specSourceRank) specDim = -1;\n newToSpecDimensionIndices[defaultDim] = specDim;\n }\n const newRank = specRank - specSourceRank + defaultSourceRank;\n for (let i = specSourceRank; i < specRank; ++i) {\n newToSpecDimensionIndices[defaultSourceRank + i - specSourceRank] = i;\n }\n const newInputScales = new Float64Array(newRank);\n const newInputCoordinateArrays = new Array(\n newRank,\n );\n const newInputUnits: string[] = [];\n for (let newDim = 0; newDim < defaultSourceRank; ++newDim) {\n const specDim = newToSpecDimensionIndices[newDim];\n if (specDim === -1 || specInputSpace === undefined) {\n newInputScales[newDim] = defaultInputSpace.scales[newDim];\n newInputUnits[newDim] = defaultInputSpace.units[newDim];\n newInputCoordinateArrays[newDim] =\n defaultInputSpace.coordinateArrays[newDim];\n } else {\n newInputScales[newDim] = specInputSpace.scales[specDim];\n newInputUnits[newDim] = specInputSpace.units[specDim];\n newInputCoordinateArrays[newDim] = mergeOptionalCoordinateArrays([\n defaultInputSpace.coordinateArrays[newDim],\n specInputSpace.coordinateArrays[specDim],\n ]);\n }\n }\n const specInputOrOutputSpace = specInputSpace || specOutputSpace;\n const newInputNames = defaultInputNames.slice(0, defaultSourceRank);\n const newOutputNames = defaultOutputSpace.names.slice(0, defaultSourceRank);\n const newOutputCoordinateArrays = defaultOutputSpace.coordinateArrays.slice(\n 0,\n defaultSourceRank,\n );\n const newOutputScales = new Float64Array(newRank);\n const newOutputUnits: string[] = [];\n for (let newDim = 0; newDim < newRank; ++newDim) {\n const specDim = newToSpecDimensionIndices[newDim];\n if (specDim === -1) {\n newOutputScales[newDim] = defaultOutputSpace.scales[newDim];\n newOutputUnits[newDim] = defaultOutputSpace.units[newDim];\n newOutputCoordinateArrays[newDim] =\n defaultOutputSpace.coordinateArrays[newDim];\n } else {\n newOutputNames[newDim] = specOutputSpace.names[specDim];\n newOutputUnits[newDim] = specOutputSpace.units[specDim];\n newOutputScales[newDim] = specOutputSpace.scales[specDim];\n newOutputCoordinateArrays[newDim] =\n specOutputSpace.coordinateArrays[specDim];\n }\n }\n if (!validateDimensionNames(newOutputNames)) {\n // Spec is incompatible, ignore it.\n this.reset();\n return;\n }\n // Handle singleton dimensions.\n for (let newDim = defaultSourceRank; newDim < newRank; ++newDim) {\n const specDim = newDim - defaultSourceRank + specSourceRank;\n newInputScales[newDim] = specInputOrOutputSpace.scales[specDim];\n newInputUnits[newDim] = specInputOrOutputSpace.units[specDim];\n newInputNames[newDim] = `${newDim}`;\n }\n\n const newTransform = new Float64Array((newRank + 1) ** 2);\n newTransform[newTransform.length - 1] = 1;\n for (let newRow = 0; newRow < newRank; ++newRow) {\n const specRow = newToSpecDimensionIndices[newRow];\n let value: number;\n if (specRow === -1 || specTransformMatrix === undefined) {\n if (newRow >= defaultSourceRank) {\n value = 0;\n } else {\n value =\n defaultTransformMatrix[defaultRank * (defaultRank + 1) + newRow] *\n (defaultOutputSpace.scales[newRow] / newOutputScales[newRow]);\n }\n } else {\n value = specTransformMatrix[specRank * (specRank + 1) + specRow];\n }\n newTransform[newRank * (newRank + 1) + newRow] = value;\n for (let newCol = 0; newCol < newRank; ++newCol) {\n const specCol = newToSpecDimensionIndices[newCol];\n let value: number;\n if ((specRow === -1) !== (specCol === -1)) {\n value = 0;\n } else if (specRow === -1 || specTransformMatrix === undefined) {\n if (specRow >= defaultSourceRank || specCol >= defaultSourceRank) {\n value = specRow === specCol ? 1 : 0;\n } else {\n value = defaultTransformMatrix[newCol * (defaultRank + 1) + newRow];\n }\n } else {\n value = specTransformMatrix[specCol * (specRank + 1) + specRow];\n }\n newTransform[newCol * (newRank + 1) + newRow] = value;\n }\n }\n const boundingBoxes = defaultInputSpace.boundingBoxes.map((boundingBox) =>\n extendTransformedBoundingBoxUpToRank(boundingBox, defaultRank, newRank),\n );\n for (let i = defaultSourceRank; i < newRank; ++i) {\n boundingBoxes.push(makeSingletonDimTransformedBoundingBox(newRank, i));\n }\n // Propagate coordinate arrays from input dimensions to output dimensions.\n for (let outputDim = 0; outputDim < newRank; ++outputDim) {\n // Check if this output dimension is identity mapped from a single input dimension.\n const translation = newTransform[newRank * (newRank + 1) + outputDim];\n if (translation !== 0) continue;\n let singleInputDim: number | undefined | null = undefined;\n for (let inputDim = 0; inputDim < newRank; ++inputDim) {\n const factor = newTransform[inputDim * (newRank + 1) + outputDim];\n if (factor === 0) continue;\n if (factor === 1) {\n if (singleInputDim === undefined) {\n // First input dimension that maps to this output dimension.\n singleInputDim = inputDim;\n } else {\n // Multiple input dimensions map to this output dimension.\n singleInputDim = null;\n break;\n }\n } else {\n // Non-identity mapping.\n singleInputDim = null;\n break;\n }\n }\n if (singleInputDim == null) continue;\n let coordinateArray = newInputCoordinateArrays[singleInputDim];\n if (coordinateArray === undefined) continue;\n if (coordinateArray.explicit) {\n coordinateArray = { ...coordinateArray, explicit: false };\n }\n newOutputCoordinateArrays[outputDim] = mergeOptionalCoordinateArrays([\n coordinateArray,\n newOutputCoordinateArrays[outputDim],\n ]);\n }\n this.value = {\n rank: newRank,\n transform: newTransform,\n sourceRank: defaultSourceRank,\n outputSpace: makeCoordinateSpace({\n rank: newRank,\n names: newOutputNames,\n scales: newOutputScales,\n units: newOutputUnits,\n coordinateArrays: newOutputCoordinateArrays,\n }),\n inputSpace: makeCoordinateSpace({\n rank: newRank,\n names: newInputNames,\n scales: newInputScales,\n units: newInputUnits,\n coordinateArrays: newInputCoordinateArrays,\n boundingBoxes,\n }),\n };\n }\n\n toJSON() {\n return coordinateTransformSpecificationToJson(this.spec);\n }\n\n restoreState(obj: unknown) {\n this.spec = coordinateTransformSpecificationFromJson(obj);\n }\n}\n\nexport function expectDimensionName(\n obj: unknown,\n allowNumericalNames = false,\n): string {\n const name = verifyString(obj);\n if (!isValidDimensionName(name, allowNumericalNames)) {\n throw new Error(`Invalid dimension name: ${JSON.stringify(name)}`);\n }\n return name;\n}\n\nexport function dimensionNamesFromJson(obj: any, allowNumericalNames = false) {\n const dimensions = parseArray(obj, (x) =>\n expectDimensionName(x, allowNumericalNames),\n );\n if (!validateDimensionNames(dimensions, allowNumericalNames)) {\n throw new Error(`Invalid dimensions: ${JSON.stringify(dimensions)}`);\n }\n return dimensions;\n}\n\ninterface BoundCoordinateSpace {\n space: WatchableValueInterface;\n prevValue: CoordinateSpace | undefined;\n mappedDimensionIds: (DimensionId | undefined)[];\n}\n\nexport class CoordinateSpaceCombiner {\n private bindings = new Set();\n\n private retainCount = 0;\n\n private prevCombined: CoordinateSpace | undefined = this.combined.value;\n\n dimensionRefCounts = new Map();\n\n getRenameValidity(newNames: readonly string[]): boolean[] {\n const existingNames = this.combined.value.names;\n const validity = getDimensionNameValidity(newNames);\n const rank = newNames.length;\n for (let i = 0; i < rank; ++i) {\n if (!validity[i]) continue;\n const newName = newNames[i];\n if (existingNames.includes(newName)) continue;\n let valid = true;\n for (const binding of this.bindings) {\n const otherNames = binding.space.value.names;\n if (otherNames.includes(newName)) {\n valid = false;\n break;\n }\n }\n validity[i] = valid;\n }\n return validity;\n }\n\n private includeDimensionPredicate_: (name: string) => boolean;\n\n get includeDimensionPredicate() {\n return this.includeDimensionPredicate_;\n }\n set includeDimensionPredicate(value: (name: string) => boolean) {\n this.includeDimensionPredicate_ = value;\n this.update();\n }\n\n constructor(\n public combined: WatchableValueInterface,\n includeDimensionPredicate: (name: string) => boolean,\n ) {\n this.includeDimensionPredicate_ = includeDimensionPredicate;\n }\n\n private update() {\n const { combined, bindings } = this;\n const retainExisting = this.retainCount > 0 ? 1 : 0;\n if (bindings.size === 0 && !retainExisting) {\n combined.value = emptyInvalidCoordinateSpace;\n return;\n }\n const include = this.includeDimensionPredicate_;\n const existing = combined.value;\n let mergedNames = Array.from(existing.names);\n let mergedUnits = Array.from(existing.units);\n let mergedScales = Array.from(existing.scales);\n let mergedIds = Array.from(existing.ids);\n let mergedTimestamps = Array.from(existing.timestamps);\n let dimensionRefs: number[] = existing.names.map(() =>\n retainExisting ? 1 : 0,\n );\n const bindingCombinedIndices: (number | undefined)[][] = [];\n let valid = false;\n for (const binding of bindings) {\n const {\n space: { value: space },\n prevValue,\n mappedDimensionIds,\n } = binding;\n valid = valid || space.valid;\n const { names, units, scales, ids, timestamps } = space;\n const newMappedDimensionIds: (DimensionId | undefined)[] = [];\n const combinedIndices: (number | undefined)[] = [];\n bindingCombinedIndices.push(combinedIndices);\n binding.mappedDimensionIds = newMappedDimensionIds;\n binding.prevValue = space;\n const rank = names.length;\n for (let i = 0; i < rank; ++i) {\n const name = names[i];\n if (!include(name)) continue;\n if (prevValue !== undefined) {\n const id = ids[i];\n const prevIndex = prevValue.ids.indexOf(id);\n if (prevIndex !== -1) {\n const combinedId = mappedDimensionIds[prevIndex];\n if (combinedId !== undefined) {\n const combinedIndex = mergedIds.indexOf(combinedId);\n if (combinedIndex !== -1) {\n newMappedDimensionIds[i] = combinedId;\n ++dimensionRefs[combinedIndex];\n combinedIndices[i] = combinedIndex;\n const timestamp = timestamps[i];\n if (\n timestamp !== undefined &&\n !(timestamp <= mergedTimestamps[combinedIndex])\n ) {\n mergedNames[combinedIndex] = name;\n mergedScales[combinedIndex] = scales[i];\n mergedUnits[combinedIndex] = units[i];\n mergedTimestamps[combinedIndex] = timestamp;\n }\n continue;\n }\n }\n }\n }\n let combinedIndex = mergedNames.indexOf(name);\n if (combinedIndex !== -1) {\n newMappedDimensionIds[i] = mergedIds[combinedIndex];\n ++dimensionRefs[combinedIndex];\n combinedIndices[i] = combinedIndex;\n continue;\n }\n combinedIndex = mergedNames.length;\n combinedIndices[i] = combinedIndex;\n dimensionRefs[combinedIndex] = 1 + retainExisting;\n mergedNames[combinedIndex] = name;\n mergedUnits[combinedIndex] = units[i];\n mergedScales[combinedIndex] = scales[i];\n mergedTimestamps[combinedIndex] = timestamps[i];\n const combinedId = newDimensionId();\n mergedIds[combinedIndex] = combinedId;\n newMappedDimensionIds[i] = combinedId;\n }\n }\n // Propagate names, units, and scales back\n const { dimensionRefCounts } = this;\n dimensionRefCounts.clear();\n let bindingIndex = 0;\n let newRank = mergedNames.length;\n for (const binding of bindings) {\n const {\n space: { value: space },\n } = binding;\n const combinedIndices = bindingCombinedIndices[bindingIndex++];\n const { rank } = space;\n const names = Array.from(space.names);\n const timestamps = Array.from(space.timestamps);\n const scales = Float64Array.from(space.scales);\n const units = Array.from(space.units);\n for (let i = 0; i < rank; ++i) {\n const combinedIndex = combinedIndices[i];\n if (combinedIndex === undefined) continue;\n units[i] = mergedUnits[combinedIndex];\n scales[i] = mergedScales[combinedIndex];\n timestamps[i] = mergedTimestamps[combinedIndex];\n names[i] = mergedNames[combinedIndex];\n }\n for (const name of names) {\n let count = dimensionRefCounts.get(name);\n if (count === undefined) {\n count = 1;\n } else {\n ++count;\n }\n dimensionRefCounts.set(name, count);\n }\n if (\n !arraysEqual(units, space.units) ||\n !arraysEqual(scales, space.scales) ||\n !arraysEqual(names, space.names) ||\n !arraysEqual(timestamps, space.timestamps)\n ) {\n const newSpace = makeCoordinateSpace({\n valid: space.valid,\n ids: space.ids,\n scales,\n units,\n names,\n timestamps,\n boundingBoxes: space.boundingBoxes,\n coordinateArrays: space.coordinateArrays,\n });\n binding.prevValue = newSpace;\n binding.space.value = newSpace;\n }\n }\n\n {\n for (let i = 0; i < newRank; ++i) {\n if (!include(mergedNames[i])) {\n dimensionRefs[i] = 0;\n }\n }\n const hasRefs = (_: any, i: number) => dimensionRefs[i] !== 0;\n mergedNames = mergedNames.filter(hasRefs);\n mergedUnits = mergedUnits.filter(hasRefs);\n mergedScales = mergedScales.filter(hasRefs);\n mergedIds = mergedIds.filter(hasRefs);\n mergedTimestamps = mergedTimestamps.filter(hasRefs);\n dimensionRefs = dimensionRefs.filter(hasRefs);\n newRank = mergedNames.length;\n }\n\n const mergedBoundingBoxes: TransformedBoundingBox[] = [];\n const allCoordinateArrays = new Array(\n newRank,\n );\n // Include any explicit coordinate arrays from `existing`.\n for (let i = 0, existingRank = existing.rank; i < existingRank; ++i) {\n const coordinateArray = existing.coordinateArrays[i];\n if (!coordinateArray?.explicit) continue;\n const newDim = mergedIds.indexOf(existing.ids[i]);\n if (newDim === -1) continue;\n allCoordinateArrays[newDim] = [coordinateArray];\n }\n for (const binding of bindings) {\n const {\n space: { value: space },\n } = binding;\n const { rank, boundingBoxes, coordinateArrays } = space;\n const newDims = space.names.map((x) => mergedNames.indexOf(x));\n for (const oldBoundingBox of boundingBoxes) {\n mergedBoundingBoxes.push(\n extendTransformedBoundingBox(oldBoundingBox, newRank, newDims),\n );\n }\n for (let i = 0; i < rank; ++i) {\n const coordinateArray = coordinateArrays[i];\n if (coordinateArray === undefined) continue;\n const newDim = newDims[i];\n const mergedList = allCoordinateArrays[newDim];\n if (mergedList === undefined) {\n allCoordinateArrays[newDim] = [coordinateArray];\n } else {\n mergedList.push(coordinateArray);\n }\n }\n }\n const mergedCoordinateArrays = new Array(\n newRank,\n );\n for (let i = 0; i < newRank; ++i) {\n const mergedList = allCoordinateArrays[i];\n if (mergedList === undefined) continue;\n mergedCoordinateArrays[i] = mergeCoordinateArrays(mergedList);\n }\n const newCombined = makeCoordinateSpace({\n valid,\n ids: mergedIds,\n names: mergedNames,\n units: mergedUnits,\n scales: new Float64Array(mergedScales),\n boundingBoxes: mergedBoundingBoxes,\n coordinateArrays: mergedCoordinateArrays,\n });\n if (retainExisting) {\n for (let i = 0; i < newRank; ++i) {\n --dimensionRefs[i];\n }\n }\n if (!coordinateSpacesEqual(existing, newCombined)) {\n this.prevCombined = newCombined;\n combined.value = newCombined;\n }\n }\n\n private handleCombinedChanged = () => {\n if (this.combined.value === this.prevCombined) return;\n this.update();\n };\n\n retain() {\n ++this.retainCount;\n return () => {\n if (--this.retainCount === 0) {\n this.update();\n }\n };\n }\n\n bind(space: WatchableValueInterface) {\n const binding = { space, mappedDimensionIds: [], prevValue: undefined };\n const { bindings } = this;\n if (bindings.size === 0) {\n this.combined.changed.add(this.handleCombinedChanged);\n }\n bindings.add(binding);\n\n const changedDisposer = space.changed.add(() => {\n if (space.value === binding.prevValue) return;\n this.update();\n });\n const disposer = () => {\n changedDisposer();\n const { bindings } = this;\n bindings.delete(binding);\n if (bindings.size === 0) {\n this.combined.changed.remove(this.handleCombinedChanged);\n }\n this.update();\n };\n this.update();\n return disposer;\n }\n}\n\nexport function homogeneousTransformSubmatrix(\n arrayConstructor: { new (n: number): T },\n oldTransform: TypedArray,\n oldRank: number,\n oldRows: readonly number[],\n oldCols: readonly number[],\n): T {\n const newRank = oldCols.length;\n const newTransform = new arrayConstructor((newRank + 1) ** 2);\n newTransform[newTransform.length - 1] = 1;\n for (let newRow = 0; newRow < newRank; ++newRow) {\n const oldRow = oldRows[newRow];\n newTransform[(newRank + 1) * newRank + newRow] =\n oldTransform[(oldRank + 1) * oldRank + oldRow];\n for (let newCol = 0; newCol < newRank; ++newCol) {\n const oldCol = oldCols[newCol];\n newTransform[(newRank + 1) * newCol + newRow] =\n oldTransform[(oldRank + 1) * oldCol + oldRow];\n }\n }\n return newTransform;\n}\n\nexport interface CoordinateTransformSpecification {\n sourceRank: number;\n transform: Float64Array | undefined;\n inputSpace: CoordinateSpace | undefined;\n outputSpace: CoordinateSpace;\n}\n\nexport function coordinateTransformSpecificationFromLegacyJson(\n obj: unknown,\n): CoordinateTransformSpecification | undefined {\n if (obj === undefined) return undefined;\n const transform = new Float64Array(16);\n if (Array.isArray(obj)) {\n if (obj.length === 16) {\n for (let i = 0; i < 4; ++i) {\n for (let j = 0; j < 4; ++j) {\n transform[i * 4 + j] = verifyFiniteFloat(obj[j * 4 + i]);\n }\n }\n } else {\n expectArray(obj, 4);\n for (let i = 0; i < 4; ++i) {\n const row = expectArray(obj[i], 4);\n for (let j = 0; j < 4; ++j) {\n transform[j * 4 + i] = verifyFiniteFloat(row[j]);\n }\n }\n }\n } else {\n verifyObject(obj);\n const rotation = quat.create();\n const translation = vec3.create();\n const scale = vec3.fromValues(1, 1, 1);\n verifyOptionalObjectProperty(obj, \"rotation\", (x) => {\n parseFiniteVec(rotation, x);\n quat.normalize(rotation, rotation);\n });\n verifyOptionalObjectProperty(obj, \"translation\", (x) => {\n parseFiniteVec(translation, x);\n });\n verifyOptionalObjectProperty(obj, \"scale\", (x) => {\n parseFiniteVec(scale, x);\n });\n const tempMat4 = mat4.create();\n mat4.fromRotationTranslationScale(tempMat4, rotation, translation, scale);\n transform.set(tempMat4);\n }\n return {\n sourceRank: 3,\n transform,\n outputSpace: makeCoordinateSpace({\n valid: true,\n names: [\"x\", \"y\", \"z\"],\n units: [\"m\", \"m\", \"m\"],\n scales: Float64Array.of(1e-9, 1e-9, 1e-9),\n }),\n inputSpace: undefined,\n };\n}\n\nexport function coordinateTransformSpecificationFromJson(\n j: unknown,\n): CoordinateTransformSpecification | undefined {\n if (j === undefined) return undefined;\n const obj = verifyObject(j);\n const outputSpace = verifyObjectProperty(\n obj,\n \"outputDimensions\",\n coordinateSpaceFromJson,\n );\n const rank = outputSpace.rank;\n const sourceRank = verifyObjectProperty(obj, \"sourceRank\", (rankObj) => {\n if (rankObj === undefined) return rank;\n if (!Number.isInteger(rankObj) || rankObj < 0 || rankObj > rank) {\n throw new Error(\n `Expected integer in range [0, ${rank}] but received: ${JSON.stringify(\n rankObj,\n )}`,\n );\n }\n return rankObj as number;\n });\n const inputSpace = verifyOptionalObjectProperty(\n obj,\n \"inputDimensions\",\n (inputSpaceObj) => {\n const space = coordinateSpaceFromJson(inputSpaceObj, true);\n if (space.rank !== rank) {\n throw new Error(\n `Expected rank of ${rank}, but received rank of: ${space.rank}`,\n );\n }\n return space;\n },\n );\n const transform = verifyOptionalObjectProperty(obj, \"matrix\", (x) => {\n const transform = new Float64Array((rank + 1) ** 2);\n const a = expectArray(x, rank);\n transform[transform.length - 1] = 1;\n for (let i = 0; i < rank; ++i) {\n try {\n const row = expectArray(a[i], rank + 1);\n for (let j = 0; j <= rank; ++j) {\n transform[(rank + 1) * j + i] = verifyFiniteFloat(row[j]);\n }\n } catch (e) {\n throw new Error(`Error in row ${i}: ${e.message}`);\n }\n }\n return transform;\n });\n return { transform, outputSpace, inputSpace, sourceRank };\n}\n\nexport function coordinateTransformSpecificationToJson(\n spec: CoordinateTransformSpecification | undefined,\n) {\n if (spec === undefined) return undefined;\n const { transform, outputSpace, inputSpace, sourceRank } = spec;\n let m: number[][] | undefined;\n const rank = outputSpace.rank;\n if (transform !== undefined) {\n m = [];\n for (let i = 0; i < rank; ++i) {\n const row: number[] = [];\n m[i] = row;\n for (let j = 0; j <= rank; ++j) {\n row[j] = transform[(rank + 1) * j + i];\n }\n }\n }\n return {\n sourceRank: sourceRank === rank ? undefined : sourceRank,\n matrix: m,\n outputDimensions: coordinateSpaceToJson(outputSpace),\n inputDimensions:\n inputSpace === undefined ? undefined : coordinateSpaceToJson(inputSpace),\n };\n}\n\nexport function permuteTransformedBoundingBox(\n boundingBox: TransformedBoundingBox,\n newToOld: readonly number[],\n oldOutputRank: number,\n): TransformedBoundingBox | undefined {\n const { box, transform } = boundingBox;\n const inputRank = boundingBox.box.lowerBounds.length;\n const outputRank = newToOld.length;\n const newTransform = new Float64Array((inputRank + 1) * outputRank);\n matrix.permuteRows(\n newTransform,\n outputRank,\n transform,\n oldOutputRank,\n newToOld,\n inputRank + 1,\n );\n if (newTransform.every((x) => x === 0)) return undefined;\n return {\n transform: newTransform,\n box,\n };\n}\n\nexport function permuteCoordinateSpace(\n existing: CoordinateSpace,\n newToOld: readonly number[],\n) {\n const { ids, names, scales, units, timestamps, coordinateArrays } = existing;\n return makeCoordinateSpace({\n rank: newToOld.length,\n valid: existing.valid,\n ids: newToOld.map((i) => ids[i]),\n names: newToOld.map((i) => names[i]),\n timestamps: newToOld.map((i) => timestamps[i]),\n scales: Float64Array.from(newToOld, (i) => scales[i]),\n units: newToOld.map((i) => units[i]),\n coordinateArrays: newToOld.map((i) => coordinateArrays[i]),\n boundingBoxes: existing.boundingBoxes\n .map((b) => permuteTransformedBoundingBox(b, newToOld, existing.rank))\n .filter((b) => b !== undefined) as TransformedBoundingBox[],\n });\n}\n\nexport function insertDimensionAt(\n existing: CoordinateSpace,\n targetIndex: number,\n sourceIndex: number,\n) {\n if (targetIndex === sourceIndex) return existing;\n return permuteCoordinateSpace(\n existing,\n getInsertPermutation(existing.rank, sourceIndex, targetIndex),\n );\n}\n\nexport function getInferredOutputScale(\n transform: CoordinateSpaceTransform,\n outputDim: number,\n): { scale: number; unit: string } | undefined {\n const { transform: transformMatrix, rank } = transform;\n const inputDims = getDependentTransformInputDimensions(\n transformMatrix,\n rank,\n [outputDim],\n );\n if (inputDims.length !== 1) return undefined;\n const [inputDim] = inputDims;\n const coeff = Math.abs(transformMatrix[(rank + 1) * inputDim + outputDim]);\n const { inputSpace } = transform;\n return {\n scale: inputSpace.scales[inputDim] * coeff,\n unit: inputSpace.units[inputDim],\n };\n}\n\nexport function getDefaultInputScale(\n transform: WatchableCoordinateSpaceTransform,\n inputDim: number,\n): { scale: number; unit: string } | undefined {\n const { scales: defaultScales, units: defaultUnits } =\n transform.defaultInputSpace;\n return inputDim < defaultScales.length\n ? { scale: defaultScales[inputDim], unit: defaultUnits[inputDim] }\n : undefined;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type {\n CoordinateSpace,\n CoordinateSpaceTransform,\n} from \"#src/coordinate_transform.js\";\nimport {\n emptyValidCoordinateSpace,\n homogeneousTransformSubmatrix,\n} from \"#src/coordinate_transform.js\";\nimport type { DisplayDimensionRenderInfo } from \"#src/navigation_state.js\";\nimport type {\n CachedWatchableValue,\n WatchableValueInterface,\n} from \"#src/trackable_value.js\";\nimport {\n constantWatchableValue,\n makeCachedDerivedWatchableValue,\n} from \"#src/trackable_value.js\";\nimport { arraysEqual, scatterUpdate } from \"#src/util/array.js\";\nimport type { ValueOrError } from \"#src/util/error.js\";\nimport type { vec3 } from \"#src/util/geom.js\";\nimport { mat4, getDependentTransformInputDimensions } from \"#src/util/geom.js\";\nimport * as matrix from \"#src/util/matrix.js\";\nimport * as vector from \"#src/util/vector.js\";\nimport { prod } from \"#src/util/vector.js\";\n\n/**\n * Specifies coordinate transform information for a RenderLayer.\n */\nexport interface RenderLayerTransform {\n /**\n * Rank of chunk/model/layer subspace used by this RenderLayer, including any additional `[0,1)`\n * padding dimensions.\n */\n rank: number;\n\n /**\n * Rank of chunk/model/layer space, excluding any padding dimensions.\n */\n unpaddedRank: number;\n\n /**\n * Specifies for each local user layer dimension the corresponding \"render layer\" dimension. A\n * value of `-1` indicates there is no corresponding \"render layer\" dimension. The combined\n * values of `localToRenderLayerDimensions` and `globalToRenderLayerDimensions` that are not `-1`\n * must be distinct and partition `[0, ..., rank)`, where `rank` is the rank of the \"model\"\n * coordinate space.\n */\n localToRenderLayerDimensions: readonly number[];\n\n /**\n * Specifies for each global dimension the corresponding \"render layer\" dimension. A value of\n * `-1` indicates there is no corresponding \"render layer\" dimension.\n */\n globalToRenderLayerDimensions: readonly number[];\n\n /**\n * Specifies for each channel dimension the corresponding \"render layer\" dimension. A value of\n * `-1` indicates there is no corresponding \"render layer\" dimension.\n */\n channelToRenderLayerDimensions: readonly number[];\n\n channelToModelDimensions: readonly number[];\n\n channelSpaceShape: Uint32Array;\n\n /**\n * Homogeneous transform from \"model\" coordinate space to \"render layer\" coordinate space.\n */\n modelToRenderLayerTransform: Float32Array;\n\n modelDimensionNames: readonly string[];\n layerDimensionNames: readonly string[];\n}\n\nexport interface ChannelSpace {\n channelCoordinateSpace: CoordinateSpace;\n // Shape of multi-dimensional channel space.\n shape: Uint32Array;\n // Total number of channels, equal to product of `shape`.\n numChannels: number;\n // Row-major array of shape `[count, rank]` specifying the coordinates for each flattened channel.\n // Channels are ordered in Fortran order.\n coordinates: Uint32Array;\n}\n\nexport const zeroRankChannelSpace: ChannelSpace = {\n channelCoordinateSpace: emptyValidCoordinateSpace,\n shape: new Uint32Array(0),\n numChannels: 1,\n coordinates: new Uint32Array(0),\n};\n\nexport function getChannelSpace(\n channelCoordinateSpace: CoordinateSpace,\n): ChannelSpace {\n const { rank } = channelCoordinateSpace;\n const {\n bounds: { lowerBounds, upperBounds },\n } = channelCoordinateSpace;\n if (lowerBounds.some((x) => x !== 0)) {\n throw new Error(\"Lower bounds of channel coordinate space must all be 0\");\n }\n if (upperBounds.some((x) => !Number.isInteger(x) || x <= 0 || x >= 2 ** 32)) {\n throw new Error(\n \"Upper bounds of channel coordinate space must all be positive integers\",\n );\n }\n const shape = new Uint32Array(upperBounds);\n const numChannels = prod(shape);\n const coordinates = new Uint32Array(numChannels * rank);\n for (let flatIndex = 0; flatIndex < numChannels; ++flatIndex) {\n let remainder = flatIndex;\n for (let dim = 0; dim < rank; ++dim) {\n const coordinate = remainder % shape[dim];\n remainder = (remainder - coordinate) / shape[dim];\n coordinates[flatIndex * rank + dim] = coordinate;\n }\n }\n return { channelCoordinateSpace, shape, numChannels, coordinates };\n}\n\nexport type RenderLayerTransformOrError = ValueOrError;\nexport type WatchableRenderLayerTransform =\n WatchableValueInterface;\n\nfunction scaleTransformSubmatrix(\n transform: Float32Array,\n rank: number,\n baseInputSpace: CoordinateSpace,\n inputToBaseDimensions: readonly number[],\n baseOutputSpace: CoordinateSpace,\n baseToOutputDimensions: readonly number[],\n) {\n const { scales: baseInputScales } = baseInputSpace;\n const { scales: baseOutputScales, rank: baseOutputRank } = baseOutputSpace;\n const stride = rank + 1;\n for (let baseOutputDim = 0; baseOutputDim < baseOutputRank; ++baseOutputDim) {\n const outputDim = baseToOutputDimensions[baseOutputDim];\n if (outputDim === -1) continue;\n const baseOutputScale = baseOutputScales[baseOutputDim];\n for (let inputDim = 0; inputDim < rank; ++inputDim) {\n const baseInputDim = inputToBaseDimensions[inputDim];\n const baseInputScale = baseInputScales[baseInputDim];\n transform[stride * inputDim + outputDim] *=\n baseInputScale / baseOutputScale;\n }\n }\n}\n\nexport function getRenderLayerTransform(\n globalCoordinateSpace: CoordinateSpace,\n localCoordinateSpace: CoordinateSpace,\n modelToLayerTransform: CoordinateSpaceTransform,\n subsourceEntry:\n | {\n subsourceToModelSubspaceTransform: Float32Array;\n modelSubspaceDimensionIndices: readonly number[];\n }\n | undefined,\n channelCoordinateSpace: CoordinateSpace = emptyValidCoordinateSpace,\n): RenderLayerTransformOrError {\n const {\n inputSpace: modelSpace,\n rank: fullRank,\n sourceRank,\n outputSpace: layerSpace,\n transform: oldTransform,\n } = modelToLayerTransform;\n const { names: modelDimensionNames } = modelSpace;\n const { names: transformOutputDimensions } = layerSpace;\n let requiredInputDims: number[];\n if (subsourceEntry !== undefined) {\n requiredInputDims = Array.from(\n subsourceEntry.modelSubspaceDimensionIndices,\n );\n } else {\n requiredInputDims = [];\n for (let i = 0; i < sourceRank; ++i) {\n requiredInputDims[i] = i;\n }\n }\n const unpaddedRank = requiredInputDims.length;\n for (let i = sourceRank; i < fullRank; ++i) {\n requiredInputDims.push(i);\n }\n const requiredOutputDims = getDependentTransformInputDimensions(\n modelToLayerTransform.transform,\n fullRank,\n requiredInputDims,\n true,\n );\n const subspaceRank = requiredInputDims.length;\n const modelSubspaceDimensionNames = requiredInputDims.map(\n (i) => modelDimensionNames[i] || `${i}`,\n );\n const layerSubspaceDimensionNames = requiredOutputDims.map(\n (i) => transformOutputDimensions[i],\n );\n if (subspaceRank !== requiredOutputDims.length) {\n return {\n error:\n \"Rank mismatch between model subspace dimensions (\" +\n modelSubspaceDimensionNames.join(\", \") +\n \") and corresponding layer/global dimensions (\" +\n layerSubspaceDimensionNames.join(\", \") +\n \")\",\n };\n }\n let newTransform = homogeneousTransformSubmatrix(\n Float32Array,\n oldTransform,\n fullRank,\n requiredOutputDims,\n requiredInputDims,\n );\n const renderLayerDimensions = requiredOutputDims.map(\n (i) => transformOutputDimensions[i],\n );\n const localToRenderLayerDimensions = localCoordinateSpace.names.map((x) =>\n renderLayerDimensions.indexOf(x),\n );\n const globalToRenderLayerDimensions = globalCoordinateSpace.names.map((x) =>\n renderLayerDimensions.indexOf(x),\n );\n scaleTransformSubmatrix(\n newTransform,\n subspaceRank,\n modelSpace,\n requiredInputDims,\n globalCoordinateSpace,\n globalToRenderLayerDimensions,\n );\n scaleTransformSubmatrix(\n newTransform,\n subspaceRank,\n modelSpace,\n requiredInputDims,\n localCoordinateSpace,\n localToRenderLayerDimensions,\n );\n const channelToRenderLayerDimensions = channelCoordinateSpace.names.map((x) =>\n renderLayerDimensions.indexOf(x),\n );\n scaleTransformSubmatrix(\n newTransform,\n subspaceRank,\n modelSpace,\n requiredInputDims,\n channelCoordinateSpace,\n channelToRenderLayerDimensions,\n );\n const channelToModelSubspaceDimensions: number[] = [];\n const channelRank = channelCoordinateSpace.rank;\n if (subsourceEntry !== undefined) {\n let { subsourceToModelSubspaceTransform } = subsourceEntry;\n if (unpaddedRank !== subspaceRank) {\n subsourceToModelSubspaceTransform = matrix.extendHomogeneousTransform(\n new Float32Array((subspaceRank + 1) ** 2),\n subspaceRank,\n subsourceToModelSubspaceTransform,\n unpaddedRank,\n );\n }\n newTransform = matrix.multiply(\n new Float32Array((subspaceRank + 1) ** 2),\n subspaceRank + 1,\n newTransform,\n subspaceRank + 1,\n subsourceToModelSubspaceTransform,\n subspaceRank + 1,\n subspaceRank + 1,\n subspaceRank + 1,\n subspaceRank + 1,\n );\n }\n const channelSpaceShape = new Uint32Array(channelRank);\n const {\n lowerBounds: channelLowerBounds,\n upperBounds: channelUpperBounds,\n voxelCenterAtIntegerCoordinates: channelVoxelCenterAtIntegerCoordinates,\n } = channelCoordinateSpace.bounds;\n for (let channelDim = 0; channelDim < channelRank; ++channelDim) {\n let lower = channelLowerBounds[channelDim];\n let upper = channelUpperBounds[channelDim];\n if (channelVoxelCenterAtIntegerCoordinates[channelDim]) {\n lower += 0.5;\n upper += 0.5;\n }\n if (\n lower !== 0 ||\n !Number.isInteger(upper) ||\n upper <= 0 ||\n upper >= 2 ** 32\n ) {\n return {\n error:\n `Channel dimension ${channelCoordinateSpace.names[channelDim]} must have ` +\n `lower bound of 0 and positive integer upper bound; current bounds are [${lower}, ${upper}]`,\n };\n }\n channelSpaceShape[channelDim] = upper;\n const layerDim = channelToRenderLayerDimensions[channelDim];\n let correspondingModelSubspaceDim = -1;\n if (layerDim !== -1) {\n for (let chunkDim = 0; chunkDim < subspaceRank; ++chunkDim) {\n const coeff = newTransform[layerDim + chunkDim * (subspaceRank + 1)];\n if (coeff === 0) continue;\n if (coeff !== 1 || correspondingModelSubspaceDim !== -1) {\n return {\n error:\n `Channel dimension ${layerSubspaceDimensionNames[layerDim]} ` +\n \"must map to a single source dimension\",\n };\n }\n correspondingModelSubspaceDim = chunkDim;\n }\n }\n channelToModelSubspaceDimensions[channelDim] =\n correspondingModelSubspaceDim;\n }\n return {\n rank: subspaceRank,\n unpaddedRank,\n modelDimensionNames: modelSubspaceDimensionNames,\n layerDimensionNames: layerSubspaceDimensionNames,\n localToRenderLayerDimensions,\n globalToRenderLayerDimensions,\n channelToRenderLayerDimensions,\n modelToRenderLayerTransform: newTransform,\n channelToModelDimensions: channelToModelSubspaceDimensions,\n channelSpaceShape,\n };\n}\n\nexport function renderLayerTransformsEqual(\n a: RenderLayerTransformOrError,\n b: RenderLayerTransformOrError,\n) {\n if (a === b) return true;\n if (a.error !== undefined || b.error !== undefined) return false;\n return (\n arraysEqual(a.modelDimensionNames, b.modelDimensionNames) &&\n arraysEqual(a.layerDimensionNames, b.layerDimensionNames) &&\n arraysEqual(\n a.globalToRenderLayerDimensions,\n b.globalToRenderLayerDimensions,\n ) &&\n arraysEqual(\n a.localToRenderLayerDimensions,\n b.localToRenderLayerDimensions,\n ) &&\n arraysEqual(\n a.channelToRenderLayerDimensions,\n b.channelToRenderLayerDimensions,\n ) &&\n arraysEqual(a.modelToRenderLayerTransform, b.modelToRenderLayerTransform) &&\n arraysEqual(a.channelSpaceShape, b.channelSpaceShape)\n );\n}\n\nexport function getWatchableRenderLayerTransform(\n globalCoordinateSpace: WatchableValueInterface,\n localCoordinateSpace: WatchableValueInterface,\n modelToLayerTransform: WatchableValueInterface,\n subsourceEntry:\n | {\n subsourceToModelSubspaceTransform: Float32Array;\n modelSubspaceDimensionIndices: readonly number[];\n }\n | undefined,\n channelCoordinateSpace?: WatchableValueInterface,\n): CachedWatchableValue {\n return makeCachedDerivedWatchableValue(\n (\n globalCoordinateSpace: CoordinateSpace,\n localCoordinateSpace: CoordinateSpace,\n modelToLayerTransform: CoordinateSpaceTransform,\n channelCoordinateSpace: CoordinateSpace | undefined,\n ) =>\n getRenderLayerTransform(\n globalCoordinateSpace,\n localCoordinateSpace,\n modelToLayerTransform,\n subsourceEntry,\n channelCoordinateSpace,\n ),\n [\n globalCoordinateSpace,\n localCoordinateSpace,\n modelToLayerTransform,\n channelCoordinateSpace === undefined\n ? constantWatchableValue(undefined)\n : channelCoordinateSpace,\n ],\n renderLayerTransformsEqual,\n );\n}\n\nexport interface LayerDisplayDimensionMapping {\n /**\n * List of indices of layer dimensions that correspond to display dimensions.\n */\n layerDisplayDimensionIndices: number[];\n\n /**\n * Maps each display dimension index to the corresponding layer dimension index, or `-1`.\n */\n displayToLayerDimensionIndices: number[];\n}\n\nexport interface ChunkChannelAccessParameters {\n channelSpaceShape: Uint32Array;\n\n /**\n * Equal to the values in `channelToChunkDimensionIndices` not equal to `-1`.\n */\n chunkChannelDimensionIndices: readonly number[];\n\n /**\n * Product of `modelTransform.channelSpaceShape`.\n */\n numChannels: number;\n\n /**\n * Row-major array of shape `[numChannels, chunkChannelDimensionIndices.length]`, specifies the\n * coordinates within the chunk channel dimensions corresponding to each flat channel index.\n */\n chunkChannelCoordinates: Uint32Array;\n}\n\nexport interface ChunkTransformParameters extends ChunkChannelAccessParameters {\n modelTransform: RenderLayerTransform;\n chunkToLayerTransform: Float32Array;\n layerToChunkTransform: Float32Array;\n chunkToLayerTransformDet: number;\n /**\n * Maps channel dimension indices in the layer channel coordinate space to the corresponding chunk\n * dimension index, or `-1` if there is no correpsonding chunk dimension.\n */\n channelToChunkDimensionIndices: readonly number[];\n combinedGlobalLocalToChunkTransform: Float32Array;\n combinedGlobalLocalRank: number;\n layerRank: number;\n}\n\nexport function layerToDisplayCoordinates(\n displayPosition: vec3,\n layerPosition: Float32Array,\n modelTransform: RenderLayerTransform,\n displayDimensionIndices: Int32Array,\n) {\n const { globalToRenderLayerDimensions } = modelTransform;\n for (let displayDim = 0; displayDim < 3; ++displayDim) {\n let v = 0;\n const globalDim = displayDimensionIndices[displayDim];\n if (globalDim !== -1) {\n const layerDim = globalToRenderLayerDimensions[globalDim];\n if (layerDim !== -1) {\n v = layerPosition[layerDim];\n }\n }\n displayPosition[displayDim] = v;\n }\n}\n\nexport function displayToLayerCoordinates(\n layerPosition: Float32Array,\n displayPosition: vec3,\n modelTransform: RenderLayerTransform,\n displayDimensionIndices: Int32Array,\n) {\n const { globalToRenderLayerDimensions } = modelTransform;\n for (let displayDim = 0; displayDim < 3; ++displayDim) {\n const globalDim = displayDimensionIndices[displayDim];\n if (globalDim !== -1) {\n const layerDim = globalToRenderLayerDimensions[globalDim];\n if (layerDim !== -1) {\n layerPosition[layerDim] = displayPosition[displayDim];\n }\n }\n }\n}\n\nexport function chunkToDisplayCoordinates(\n displayPosition: vec3,\n chunkPosition: Float32Array,\n chunkTransform: ChunkTransformParameters,\n displayDimensionIndices: Int32Array,\n): vec3 {\n const { globalToRenderLayerDimensions } = chunkTransform.modelTransform;\n const { layerRank, chunkToLayerTransform } = chunkTransform;\n const stride = layerRank + 1;\n for (let displayDim = 0; displayDim < 3; ++displayDim) {\n let sum = 0;\n const globalDim = displayDimensionIndices[displayDim];\n if (globalDim !== -1) {\n const layerDim = globalToRenderLayerDimensions[globalDim];\n if (layerDim !== -1) {\n sum = chunkToLayerTransform[stride * layerRank + layerDim];\n for (let chunkDim = 0; chunkDim < layerRank; ++chunkDim) {\n sum +=\n chunkToLayerTransform[stride * chunkDim + layerDim] *\n chunkPosition[chunkDim];\n }\n }\n }\n displayPosition[displayDim] = sum;\n }\n return displayPosition;\n}\n\nexport interface ChunkDisplayTransformParameters {\n modelTransform: RenderLayerTransform;\n chunkTransform: ChunkTransformParameters;\n displaySubspaceModelMatrix: mat4;\n displaySubspaceInvModelMatrix: mat4;\n chunkDisplayDimensionIndices: number[];\n numChunkDisplayDims: number;\n}\n\nexport function getChunkTransformParameters(\n modelTransform: RenderLayerTransform,\n chunkToModelTransform?: Float32Array,\n): ChunkTransformParameters {\n const layerRank = modelTransform.rank;\n const unpaddedRank = modelTransform.unpaddedRank;\n let chunkToLayerTransform: Float32Array;\n if (unpaddedRank !== layerRank && chunkToModelTransform !== undefined) {\n chunkToModelTransform = matrix.extendHomogeneousTransform(\n new Float32Array((layerRank + 1) ** 2),\n layerRank,\n chunkToModelTransform,\n unpaddedRank,\n );\n }\n if (chunkToModelTransform !== undefined) {\n chunkToLayerTransform = new Float32Array((layerRank + 1) * (layerRank + 1));\n matrix.multiply(\n chunkToLayerTransform,\n layerRank + 1,\n modelTransform.modelToRenderLayerTransform,\n layerRank + 1,\n chunkToModelTransform,\n layerRank + 1,\n layerRank + 1,\n layerRank + 1,\n layerRank + 1,\n );\n } else {\n chunkToLayerTransform = modelTransform.modelToRenderLayerTransform;\n }\n const layerToChunkTransform = new Float32Array(\n (layerRank + 1) * (layerRank + 1),\n );\n const det = matrix.inverse(\n layerToChunkTransform,\n layerRank + 1,\n chunkToLayerTransform,\n layerRank + 1,\n layerRank + 1,\n );\n if (det === 0) {\n throw new Error(\"Transform is singular\");\n }\n const {\n globalToRenderLayerDimensions,\n localToRenderLayerDimensions,\n channelToRenderLayerDimensions,\n } = modelTransform;\n const globalRank = globalToRenderLayerDimensions.length;\n const localRank = localToRenderLayerDimensions.length;\n const combinedGlobalLocalRank = globalRank + localRank;\n\n // Compute `combinedGlobalLocalToChunkTransform`.\n const combinedGlobalLocalToChunkTransform = new Float32Array(\n (combinedGlobalLocalRank + 1) * layerRank,\n );\n for (let chunkDim = 0; chunkDim < layerRank; ++chunkDim) {\n for (let globalDim = 0; globalDim < globalRank; ++globalDim) {\n const layerDim = globalToRenderLayerDimensions[globalDim];\n if (layerDim === -1) continue;\n combinedGlobalLocalToChunkTransform[chunkDim + globalDim * layerRank] =\n layerToChunkTransform[chunkDim + layerDim * (layerRank + 1)];\n }\n for (let localDim = 0; localDim < localRank; ++localDim) {\n const layerDim = localToRenderLayerDimensions[localDim];\n if (layerDim === -1) continue;\n combinedGlobalLocalToChunkTransform[\n chunkDim + (globalRank + localDim) * layerRank\n ] = layerToChunkTransform[chunkDim + layerDim * (layerRank + 1)];\n }\n combinedGlobalLocalToChunkTransform[\n chunkDim + combinedGlobalLocalRank * layerRank\n ] = layerToChunkTransform[chunkDim + layerRank * (layerRank + 1)];\n }\n\n const channelRank = channelToRenderLayerDimensions.length;\n const channelToChunkDimensionIndices = new Array(channelRank);\n const chunkChannelDimensionIndices: number[] = [];\n for (let channelDim = 0; channelDim < channelRank; ++channelDim) {\n const layerDim = channelToRenderLayerDimensions[channelDim];\n let correspondingChunkDim = -1;\n if (layerDim !== -1) {\n for (let chunkDim = 0; chunkDim < layerRank; ++chunkDim) {\n const coeff =\n chunkToLayerTransform[layerDim + chunkDim * (layerRank + 1)];\n if (coeff === 0) continue;\n if (coeff !== 1 || correspondingChunkDim !== -1) {\n throw new Error(\n `Channel dimension ${modelTransform.layerDimensionNames[layerDim]} ` +\n \"must map with stride 1 to a single data chunk dimensions\",\n );\n }\n correspondingChunkDim = chunkDim;\n }\n if (correspondingChunkDim !== -1) {\n const offset =\n chunkToLayerTransform[layerDim + layerRank * (layerRank + 1)];\n if (offset !== 0 && offset !== -0.5) {\n throw new Error(\n `Channel dimension ${modelTransform.layerDimensionNames[layerDim]} ` +\n `must have an offset of 0 in the chunk coordinate space; current offset is ${offset}`,\n );\n }\n chunkChannelDimensionIndices.push(correspondingChunkDim);\n }\n }\n channelToChunkDimensionIndices[channelDim] = correspondingChunkDim;\n }\n const { channelSpaceShape } = modelTransform;\n const numChannels = vector.prod(channelSpaceShape);\n const chunkChannelRank = chunkChannelDimensionIndices.length;\n const chunkChannelCoordinates = new Uint32Array(\n numChannels * chunkChannelRank,\n );\n for (let channelIndex = 0; channelIndex < numChannels; ++channelIndex) {\n let remainder = channelIndex;\n let chunkChannelDim = 0;\n for (let channelDim = 0; channelDim < channelRank; ++channelDim) {\n const coordinate = remainder % channelSpaceShape[channelDim];\n remainder = (remainder - coordinate) / channelSpaceShape[channelDim];\n const chunkDim = channelToChunkDimensionIndices[channelDim];\n if (chunkDim !== -1) {\n chunkChannelCoordinates[\n channelIndex * chunkChannelRank + chunkChannelDim\n ] = coordinate;\n ++chunkChannelDim;\n }\n }\n }\n return {\n layerRank: layerRank,\n modelTransform,\n chunkToLayerTransform,\n layerToChunkTransform,\n chunkToLayerTransformDet: det,\n combinedGlobalLocalRank,\n combinedGlobalLocalToChunkTransform,\n channelToChunkDimensionIndices,\n chunkChannelDimensionIndices,\n numChannels,\n chunkChannelCoordinates,\n channelSpaceShape,\n };\n}\n\nexport function getLayerDisplayDimensionMapping(\n transform: RenderLayerTransform,\n displayDimensionIndices: Int32Array,\n): LayerDisplayDimensionMapping {\n const { globalToRenderLayerDimensions } = transform;\n\n // List of layer dimension indices corresponding to global display dimensions.\n const layerDisplayDimensionIndices: number[] = [];\n\n // Maps global display dimension (in {0, 1, 2}) to the corresponding layer dimension index, or\n // `-1`.\n const displayToLayerDimensionIndices: number[] = [];\n\n for (let displayDim = 0; displayDim < 3; ++displayDim) {\n const globalDim = displayDimensionIndices[displayDim];\n if (globalDim === -1) continue;\n const layerDim = globalToRenderLayerDimensions[globalDim];\n displayToLayerDimensionIndices.push(layerDim);\n if (layerDim === -1) continue;\n layerDisplayDimensionIndices.push(layerDim);\n }\n for (let i = displayToLayerDimensionIndices.length; i < 3; ++i) {\n displayToLayerDimensionIndices[i] = -1;\n }\n return { layerDisplayDimensionIndices, displayToLayerDimensionIndices };\n}\n\nexport function getChunkDisplayTransformParameters(\n chunkTransform: ChunkTransformParameters,\n layerDisplayDimensionMapping: LayerDisplayDimensionMapping,\n): ChunkDisplayTransformParameters {\n const { chunkToLayerTransform, modelTransform } = chunkTransform;\n const rank = modelTransform.rank;\n const { layerDisplayDimensionIndices, displayToLayerDimensionIndices } =\n layerDisplayDimensionMapping;\n const numLayerDisplayDims = layerDisplayDimensionIndices.length;\n const chunkDisplayDimensionIndices = getDependentTransformInputDimensions(\n chunkToLayerTransform,\n rank,\n layerDisplayDimensionIndices,\n );\n if (chunkDisplayDimensionIndices.length !== numLayerDisplayDims) {\n const { modelDimensionNames, layerDimensionNames } = modelTransform;\n throw new Error(\n \"Rank mismatch between displayed layer dimensions \" +\n `(${Array.from(\n layerDisplayDimensionIndices,\n (i) => layerDimensionNames[i],\n ).join(\",\\u00a0\")}) ` +\n \"and corresponding chunk dimensions \" +\n `(${Array.from(\n chunkDisplayDimensionIndices,\n (i) => modelDimensionNames[i],\n ).join(\",\\u00a0\")})`,\n );\n }\n // Compute \"model matrix\" (transform from the displayed subspace of the chunk space) to the global\n // display coordinate space.\n const displaySubspaceModelMatrix = mat4.create();\n for (let displayDim = 0; displayDim < 3; ++displayDim) {\n const layerDim = displayToLayerDimensionIndices[displayDim];\n if (layerDim === -1) continue;\n for (\n let chunkDisplayDimIndex = 0;\n chunkDisplayDimIndex < numLayerDisplayDims;\n ++chunkDisplayDimIndex\n ) {\n const chunkDim = chunkDisplayDimensionIndices[chunkDisplayDimIndex];\n displaySubspaceModelMatrix[chunkDisplayDimIndex * 4 + displayDim] =\n chunkToLayerTransform[chunkDim * (rank + 1) + layerDim];\n }\n displaySubspaceModelMatrix[12 + displayDim] =\n chunkToLayerTransform[rank * (rank + 1) + layerDim];\n }\n const displaySubspaceInvModelMatrix = mat4.create();\n mat4.invert(displaySubspaceInvModelMatrix, displaySubspaceModelMatrix);\n\n for (let i = chunkDisplayDimensionIndices.length; i < 3; ++i) {\n chunkDisplayDimensionIndices[i] = -1;\n }\n return {\n modelTransform: chunkTransform.modelTransform,\n chunkTransform,\n displaySubspaceModelMatrix,\n displaySubspaceInvModelMatrix,\n chunkDisplayDimensionIndices,\n numChunkDisplayDims: numLayerDisplayDims,\n };\n}\n\nexport function getChunkPositionFromCombinedGlobalLocalPositions(\n chunkPosition: Float32Array,\n globalPosition: Float32Array,\n localPosition: Float32Array,\n layerRank: number,\n combinedGlobalLocalToChunkTransform: Float32Array,\n) {\n const globalRank = globalPosition.length;\n const localRank = localPosition.length;\n const rank = chunkPosition.length;\n let valid = true;\n for (let chunkDim = 0; chunkDim < layerRank; ++chunkDim) {\n let off = chunkDim;\n let sum = 0;\n for (let globalDim = 0; globalDim < globalRank; ++globalDim) {\n sum +=\n combinedGlobalLocalToChunkTransform[off + globalDim * layerRank] *\n globalPosition[globalDim];\n }\n off += globalRank * layerRank;\n for (let localDim = 0; localDim < localRank; ++localDim) {\n sum +=\n combinedGlobalLocalToChunkTransform[off + localDim * layerRank] *\n localPosition[localDim];\n }\n sum += combinedGlobalLocalToChunkTransform[off + localRank * layerRank];\n if (chunkDim < rank) {\n chunkPosition[chunkDim] = sum;\n } else {\n // Handle clipping\n if (sum < 0 || sum >= 1) {\n valid = false;\n }\n }\n }\n return valid;\n}\n\nexport function getLayerPositionFromCombinedGlobalLocalPositions(\n layerPosition: Float32Array,\n globalPosition: Float32Array,\n localPosition: Float32Array,\n modelTransform: RenderLayerTransform,\n) {\n scatterUpdate(\n layerPosition,\n globalPosition,\n modelTransform.globalToRenderLayerDimensions,\n );\n scatterUpdate(\n layerPosition,\n localPosition,\n modelTransform.localToRenderLayerDimensions,\n );\n return layerPosition;\n}\n\nexport function get3dModelToDisplaySpaceMatrix(\n out: mat4,\n displayDimensionRenderInfo: DisplayDimensionRenderInfo,\n transform: RenderLayerTransform,\n) {\n out.fill(0);\n out[15] = 1;\n let fullRank = true;\n const { displayDimensionIndices } = displayDimensionRenderInfo;\n const { globalToRenderLayerDimensions, modelToRenderLayerTransform } =\n transform;\n const layerRank = transform.rank;\n for (let displayDim = 0; displayDim < 3; ++displayDim) {\n const globalDim = displayDimensionIndices[displayDim];\n if (globalDim === -1) {\n fullRank = false;\n continue;\n }\n const layerDim = globalToRenderLayerDimensions[globalDim];\n if (layerDim === -1) {\n fullRank = false;\n continue;\n }\n out[displayDim + 12] =\n modelToRenderLayerTransform[layerDim + layerRank * (layerRank + 1)];\n for (let modelDim = 0; modelDim < 3; ++modelDim) {\n out[displayDim + 4 * modelDim] =\n modelToRenderLayerTransform[layerDim + (layerRank + 1) * modelDim];\n }\n }\n if (!fullRank) {\n const { globalDimensionNames } = displayDimensionRenderInfo;\n const displayDimDesc = Array.from(\n displayDimensionIndices.filter((i) => i !== -1),\n (i) => globalDimensionNames[i],\n ).join(\",\\u00a0\");\n throw new Error(\n `Transform from model dimensions (${transform.modelDimensionNames.join(\n \",\\u00a0\",\n )}) ` +\n `to display dimensions (${displayDimDesc}) does not have full rank`,\n );\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport enum ChunkState {\n // Chunk is stored in GPU memory in addition to system memory.\n GPU_MEMORY = 0,\n // Chunk is stored only in system memory but not in GPU memory.\n SYSTEM_MEMORY = 1,\n\n // Chunk is stored in system memory on worker.\n SYSTEM_MEMORY_WORKER = 2,\n\n // Chunk is downloading.\n DOWNLOADING = 3,\n // Chunk is not yet downloading.\n QUEUED = 4,\n\n // Chunk has just been added.\n NEW = 5,\n\n // Download failed.\n FAILED = 6,\n\n EXPIRED = 7,\n\n // If new states are added, keep numChangeStates in sync.\n}\n\nexport const numChunkStates = 8;\n\nexport enum ChunkPriorityTier {\n FIRST_TIER = 0,\n // eslint-disable-next-line @typescript-eslint/no-duplicate-enum-values\n FIRST_ORDERED_TIER = 0,\n // eslint-disable-next-line @typescript-eslint/no-duplicate-enum-values\n VISIBLE = 0,\n PREFETCH = 1,\n // eslint-disable-next-line @typescript-eslint/no-duplicate-enum-values\n LAST_ORDERED_TIER = 1,\n RECENT = 2,\n // eslint-disable-next-line @typescript-eslint/no-duplicate-enum-values\n LAST_TIER = 2,\n}\n\nexport const numChunkPriorityTiers = 3;\n\nexport enum ChunkDownloadStatistics {\n totalTime = 0,\n totalChunks = 1,\n}\n\nexport enum ChunkMemoryStatistics {\n numChunks = 0,\n systemMemoryBytes = 1,\n gpuMemoryBytes = 2,\n}\n\nexport const numChunkMemoryStatistics = 3;\n\nexport const numChunkDownloadStatistics = 2;\n\nexport const numChunkStatistics =\n numChunkStates * numChunkPriorityTiers * numChunkMemoryStatistics +\n numChunkDownloadStatistics;\n\nexport function getChunkStateStatisticIndex(\n state: ChunkState,\n priorityTier: ChunkPriorityTier,\n) {\n return state * numChunkPriorityTiers + priorityTier;\n}\n\nexport function getChunkDownloadStatisticIndex(\n statistic: ChunkDownloadStatistics,\n) {\n return (\n numChunkStates * numChunkPriorityTiers * numChunkMemoryStatistics +\n statistic\n );\n}\n\nexport const PREFETCH_PRIORITY_MULTIPLIER = 1e13;\n\nexport const CHUNK_QUEUE_MANAGER_RPC_ID = \"ChunkQueueManager\";\nexport const CHUNK_MANAGER_RPC_ID = \"ChunkManager\";\nexport const CHUNK_SOURCE_INVALIDATE_RPC_ID = \"ChunkSource.invalidate\";\n\nexport const REQUEST_CHUNK_STATISTICS_RPC_ID =\n \"ChunkQueueManager.requestChunkStatistics\";\n\n// Used for sending per-layer visible/prefetch chunk statistics from backend to frontend.\nexport const CHUNK_LAYER_STATISTICS_RPC_ID =\n \"ChunkManager.chunkLayerStatistics\";\n\nexport interface ChunkSourceParametersConstructor {\n new (): T;\n RPC_ID: string;\n}\n\nexport class LayerChunkProgressInfo {\n numVisibleChunksNeeded = 0;\n numVisibleChunksAvailable = 0;\n numPrefetchChunksNeeded = 0;\n numPrefetchChunksAvailable = 0;\n}\n","/**\n * @license\n * Copyright 2024 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport enum FrameTimingMethod {\n MEDIAN = 0,\n MEAN = 1,\n MAX = 2,\n}\n\nexport class FramerateMonitor {\n private timeElapsedQueries: (WebGLQuery | null)[] = [];\n private warnedAboutMissingExtension = false;\n private storedTimeDeltas: number[] = [];\n\n constructor(\n private numStoredTimes: number = 10,\n private queryPoolSize: number = 10,\n ) {\n if (this.queryPoolSize < 1) {\n throw new Error(\n `Query pool size must be at least 1, but got ${queryPoolSize}.`,\n );\n }\n }\n\n getTimingExtension(gl: WebGL2RenderingContext) {\n const ext = gl.getExtension(\"EXT_disjoint_timer_query_webgl2\");\n if (ext === null && !this.warnedAboutMissingExtension) {\n console.log(\n \"EXT_disjoint_timer_query_webgl2 extension not available. \" +\n \"Cannot measure frame time.\",\n );\n this.warnedAboutMissingExtension = true;\n }\n return ext;\n }\n\n startFrameTimeQuery(gl: WebGL2RenderingContext, ext: any) {\n if (ext === null) {\n return null;\n }\n const query = gl.createQuery();\n if (query !== null) {\n gl.beginQuery(ext.TIME_ELAPSED_EXT, query);\n }\n return query;\n }\n\n endFrameTimeQuery(\n gl: WebGL2RenderingContext,\n ext: any,\n query: WebGLQuery | null,\n ) {\n if (ext !== null && query !== null) {\n gl.endQuery(ext.TIME_ELAPSED_EXT);\n }\n if (this.timeElapsedQueries.length >= this.queryPoolSize) {\n const oldestQuery = this.timeElapsedQueries.shift();\n if (oldestQuery !== null && oldestQuery !== undefined) {\n gl.deleteQuery(oldestQuery);\n }\n }\n this.timeElapsedQueries.push(query);\n }\n\n grabAnyFinishedQueryResults(gl: WebGL2RenderingContext) {\n const deletedQueryIndices: number[] = [];\n for (let i = 0; i < this.timeElapsedQueries.length; i++) {\n const query = this.timeElapsedQueries[i];\n if (query !== null) {\n const available = gl.getQueryParameter(\n query,\n gl.QUERY_RESULT_AVAILABLE,\n );\n if (available) {\n const result = gl.getQueryParameter(query, gl.QUERY_RESULT) / 1e6;\n this.storedTimeDeltas.push(result);\n gl.deleteQuery(query);\n deletedQueryIndices.push(i);\n }\n }\n }\n for (let i = deletedQueryIndices.length - 1; i >= 0; i--) {\n this.timeElapsedQueries.splice(i, 1);\n }\n if (this.storedTimeDeltas.length > this.numStoredTimes) {\n this.storedTimeDeltas = this.storedTimeDeltas.slice(-this.numStoredTimes);\n }\n }\n\n getLastFrameTimesInMs(numberOfFrames: number = 10) {\n return this.storedTimeDeltas.slice(-numberOfFrames);\n }\n\n getQueries() {\n return this.timeElapsedQueries;\n }\n}\n\nexport class DownsamplingBasedOnFrameRateCalculator {\n private lastFrameTime: number | null = null;\n private frameDeltas: number[] = [];\n private downsamplingRates: Map = new Map();\n private frameCount = 0;\n\n /**\n * @param numberOfStoredFrameDeltas The number of frame deltas to store. Oldest frame deltas are removed. Must be at least 1.\n * @param maxDownsamplingFactor The maximum factor for downsampling. Must be at least 2.\n * @param desiredFrameTimingMs The desired frame timing in milliseconds. The downsampling rate is based on a comparison of the actual frame timing to this value.\n * @param downsamplingPersistenceDurationInFrames The max number of frames over which a high downsampling rate persists.\n */\n constructor(\n public numberOfStoredFrameDeltas: number = 10,\n private maxDownsamplingFactor: number = 8,\n private desiredFrameTimingMs = 1000 / 60,\n private downsamplingPersistenceDurationInFrames = 15,\n ) {\n this.validateConstructorArguments();\n for (let i = 1; i <= this.maxDownsamplingFactor; i *= 2) {\n this.downsamplingRates.set(i, -Infinity);\n }\n }\n\n private validateConstructorArguments() {\n this.numberOfStoredFrameDeltas = Math.max(\n 1,\n Math.round(this.numberOfStoredFrameDeltas),\n );\n this.maxDownsamplingFactor = Math.max(\n 2,\n Math.round(this.maxDownsamplingFactor),\n );\n }\n\n private storeFrameDelta(frameDelta: number) {\n this.frameDeltas.push(frameDelta);\n if (this.frameDeltas.length > this.numberOfStoredFrameDeltas) {\n this.frameDeltas.shift();\n }\n }\n\n private calculateMeanFrameTime(): number {\n return (\n this.frameDeltas.reduce((a, b) => a + b, 0) / this.frameDeltas.length\n );\n }\n\n private calculateMedianFrameTime(): number {\n const sortedFrameDeltas = this.frameDeltas.slice().sort((a, b) => a - b);\n const midpoint = Math.floor(sortedFrameDeltas.length / 2);\n return sortedFrameDeltas.length % 2 === 1\n ? sortedFrameDeltas[midpoint]\n : (sortedFrameDeltas[midpoint - 1] + sortedFrameDeltas[midpoint]) / 2;\n }\n\n private calculateMaxFrameTime(): number {\n return Math.max(...this.frameDeltas);\n }\n\n private updateMaxTrackedDownsamplingRate(downsampleFactor: number) {\n this.downsamplingRates.set(downsampleFactor, this.frameCount);\n let maxTrackedDownsamplingRate = 1;\n for (const [downsamplingRate, frameCount] of this.downsamplingRates) {\n if (\n this.frameCount - frameCount <=\n this.downsamplingPersistenceDurationInFrames\n ) {\n maxTrackedDownsamplingRate = downsamplingRate;\n }\n }\n return maxTrackedDownsamplingRate;\n }\n\n /* This doesn't reset stored frame deltas. Is usually called on a new continous camera move */\n resetForNewFrameSet() {\n this.lastFrameTime = null;\n this.frameCount = 0;\n this.downsamplingRates.forEach((_, key) => {\n this.downsamplingRates.set(key, -Infinity);\n });\n }\n\n addFrame(timestamp: number = Date.now()) {\n if (this.lastFrameTime !== null) {\n const frameDelta = timestamp - this.lastFrameTime;\n if (frameDelta > 0) {\n this.storeFrameDelta(frameDelta);\n }\n }\n this.lastFrameTime = timestamp;\n this.frameCount++;\n }\n\n calculateFrameTimeInMs(\n method: FrameTimingMethod = FrameTimingMethod.MAX,\n ): number {\n if (this.frameDeltas.length === 0) {\n return 0;\n }\n switch (method) {\n case FrameTimingMethod.MEDIAN:\n return this.calculateMedianFrameTime();\n case FrameTimingMethod.MEAN:\n return this.calculateMeanFrameTime();\n case FrameTimingMethod.MAX:\n return this.calculateMaxFrameTime();\n }\n }\n\n /** Should be called once per frame for proper downsampling persistence */\n calculateDownsamplingRate(\n method: FrameTimingMethod = FrameTimingMethod.MEAN,\n ): number {\n const calculatedFrameTime = this.calculateFrameTimeInMs(method);\n if (calculatedFrameTime === 0) {\n // Don't add this one to tracking, it's just to start the process\n return Math.min(4, this.maxDownsamplingFactor);\n }\n let downsampleFactorBasedOnFramerate = Math.max(\n calculatedFrameTime / this.desiredFrameTimingMs,\n 1,\n );\n // Round to the nearest power of 2.\n downsampleFactorBasedOnFramerate = Math.min(\n Math.pow(2, Math.round(Math.log2(downsampleFactorBasedOnFramerate))),\n this.maxDownsamplingFactor,\n );\n return this.updateMaxTrackedDownsamplingRate(\n downsampleFactorBasedOnFramerate,\n );\n }\n\n getFrameDeltas(): number[] {\n return this.frameDeltas;\n }\n\n getFrameCount(): number {\n return this.frameCount;\n }\n\n getDownsamplingRates(): Map {\n return this.downsamplingRates;\n }\n\n setFrameDeltas(frameDeltas: number[], incrementFrameCount = true) {\n this.frameDeltas = frameDeltas.slice(-this.numberOfStoredFrameDeltas);\n if (incrementFrameCount) {\n this.frameCount++;\n }\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { debounce } from \"lodash-es\";\n\nimport type { FrameNumberCounter } from \"#src/chunk_manager/frontend.js\";\nimport { TrackableValue } from \"#src/trackable_value.js\";\nimport { animationFrameDebounce } from \"#src/util/animation_frame_debounce.js\";\nimport type { Borrowed } from \"#src/util/disposable.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { FramerateMonitor } from \"#src/util/framerate.js\";\nimport type { mat4 } from \"#src/util/geom.js\";\nimport { parseFixedLengthArray, verifyFloat01 } from \"#src/util/json.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport type { WatchableVisibilityPriority } from \"#src/visibility_priority/frontend.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport { initializeWebGL } from \"#src/webgl/context.js\";\n\nconst DELAY_AFTER_CONTINUOUS_CAMERA_MOTION_MS = 300;\n\nexport class RenderViewport {\n // Width of visible portion of panel in canvas pixels.\n width = 0;\n\n // Height of visible portion of panel in canvas pixels.\n height = 0;\n\n // Width in canvas pixels, including portions outside of the canvas (i.e. outside the \"viewport\"\n // window).\n logicalWidth = 0;\n\n // Height in canvas pixels, including portions outside of the canvas (i.e. outside the \"viewport\"\n // window).\n logicalHeight = 0;\n\n // Left edge of visible region within full (logical) panel, as fraction in [0, 1].\n visibleLeftFraction = 0;\n\n // Top edge of visible region within full (logical) panel, as fraction in [0, 1].\n visibleTopFraction = 0;\n\n // Fraction of logical width that is visible, equal to `widthInCanvasPixels / logicalWidth`.\n visibleWidthFraction = 0;\n\n // Fraction of logical height that is visible, equal to `heightInCanvasPixels / logicalHeight`.\n visibleHeightFraction = 0;\n}\n\nexport function applyRenderViewportToProjectionMatrix(\n viewport: RenderViewport,\n projectionMatrix: mat4,\n) {\n const xScale = 1 / viewport.visibleWidthFraction;\n const yScale = 1 / viewport.visibleHeightFraction;\n const xOffset = -1 - (-1 + 2 * viewport.visibleLeftFraction) * xScale;\n let yOffset = -1 - (-1 + 2 * viewport.visibleTopFraction) * yScale;\n yOffset = -yOffset;\n projectionMatrix[0] =\n projectionMatrix[0] * xScale + projectionMatrix[3] * xOffset;\n projectionMatrix[4] =\n projectionMatrix[4] * xScale + projectionMatrix[7] * xOffset;\n projectionMatrix[8] =\n projectionMatrix[8] * xScale + projectionMatrix[11] * xOffset;\n projectionMatrix[12] =\n projectionMatrix[12] * xScale + projectionMatrix[15] * xOffset;\n\n projectionMatrix[1] =\n projectionMatrix[1] * yScale + projectionMatrix[3] * yOffset;\n projectionMatrix[5] =\n projectionMatrix[5] * yScale + projectionMatrix[7] * yOffset;\n projectionMatrix[9] =\n projectionMatrix[9] * yScale + projectionMatrix[11] * yOffset;\n projectionMatrix[13] =\n projectionMatrix[13] * yScale + projectionMatrix[15] * yOffset;\n}\n\nexport function renderViewportsEqual(a: RenderViewport, b: RenderViewport) {\n return (\n a.width === b.width &&\n a.height === b.height &&\n a.logicalWidth === b.logicalWidth &&\n a.logicalHeight === b.logicalHeight &&\n a.visibleLeftFraction === b.visibleLeftFraction &&\n a.visibleTopFraction === b.visibleTopFraction\n );\n}\n\nexport abstract class RenderedPanel extends RefCounted {\n gl: GL;\n\n // Generation used to check whether the following bounds-related fields are up to date.\n boundsGeneration = -1;\n\n // Offset of visible portion of panel in canvas pixels from left side of canvas.\n canvasRelativeClippedLeft = 0;\n\n // Offset of visible portion of panel in canvas pixels from top of canvas.\n canvasRelativeClippedTop = 0;\n\n canvasRelativeLogicalLeft = 0;\n canvasRelativeLogicalTop = 0;\n\n renderViewport = new RenderViewport();\n\n private monitorState: PanelMonitorState = {};\n\n constructor(\n public context: Borrowed,\n public element: HTMLElement,\n public visibility: WatchableVisibilityPriority,\n ) {\n super();\n this.gl = context.gl;\n context.addPanel(this);\n }\n\n scheduleRedraw() {\n if (this.visible) {\n this.context.scheduleRedraw();\n }\n }\n\n abstract isReady(): boolean;\n\n ensureBoundsUpdated() {\n const { context } = this;\n context.ensureBoundsUpdated();\n const { boundsGeneration } = context;\n if (boundsGeneration === this.boundsGeneration) return;\n this.boundsGeneration = boundsGeneration;\n const { element } = this;\n const clientRect = element.getBoundingClientRect();\n context.ensureMonitorPanel(element, this.monitorState, clientRect);\n const root = context.container;\n const canvasRect = context.canvasRect!;\n const { canvas } = context;\n const { width: canvasPixelWidth, height: canvasPixelHeight } = canvas;\n const screenToCanvasPixelScaleX = canvasPixelWidth / canvasRect.width;\n const screenToCanvasPixelScaleY = canvasPixelHeight / canvasRect.height;\n // Logical bounding rectangle in canvas/WebGL pixels (which may be a different size than screen\n // pixels when using a fixed canvas size via the Python integration).\n const canvasLeft = canvasRect.left;\n const canvasTop = canvasRect.top;\n const logicalLeft = (this.canvasRelativeLogicalLeft = Math.round(\n (clientRect.left - canvasLeft) * screenToCanvasPixelScaleX +\n element.clientLeft,\n ));\n const logicalTop = (this.canvasRelativeLogicalTop = Math.round(\n (clientRect.top - canvasTop) * screenToCanvasPixelScaleY +\n element.clientTop,\n ));\n const logicalWidth = element.clientWidth;\n const logicalHeight = element.clientHeight;\n const logicalRight = logicalLeft + logicalWidth;\n const logicalBottom = logicalTop + logicalHeight;\n // Clipped bounding rectangle in canvas/WebGL pixels. The clipped bounding rectangle is the\n // portion actually visible and overlapping the canvas.\n let clippedTop = logicalTop;\n let clippedLeft = logicalLeft;\n let clippedRight = logicalRight;\n let clippedBottom = logicalBottom;\n for (\n let parent = element.parentElement;\n parent !== null && parent !== root;\n parent = parent.parentElement\n ) {\n const rect = parent.getBoundingClientRect();\n if (\n rect.x === 0 &&\n rect.y === 0 &&\n rect.width === 0 &&\n rect.height === 0\n ) {\n // Assume this is a `display: contents;` element.\n continue;\n }\n clippedLeft = Math.max(\n clippedLeft,\n (rect.left - canvasLeft) * screenToCanvasPixelScaleX,\n );\n clippedTop = Math.max(\n clippedTop,\n (rect.top - canvasTop) * screenToCanvasPixelScaleY,\n );\n clippedRight = Math.min(\n clippedRight,\n (rect.right - canvasLeft) * screenToCanvasPixelScaleX,\n );\n clippedBottom = Math.min(\n clippedBottom,\n (rect.bottom - canvasTop) * screenToCanvasPixelScaleY,\n );\n }\n clippedTop = this.canvasRelativeClippedTop = Math.round(\n Math.max(clippedTop, 0),\n );\n clippedLeft = this.canvasRelativeClippedLeft = Math.round(\n Math.max(clippedLeft, 0),\n );\n clippedRight = Math.round(Math.min(clippedRight, canvasPixelWidth));\n clippedBottom = Math.round(Math.min(clippedBottom, canvasPixelHeight));\n const viewport = this.renderViewport;\n const clippedWidth = (viewport.width = Math.max(\n 0,\n clippedRight - clippedLeft,\n ));\n const clippedHeight = (viewport.height = Math.max(\n 0,\n clippedBottom - clippedTop,\n ));\n viewport.logicalWidth = logicalWidth;\n viewport.logicalHeight = logicalHeight;\n viewport.visibleLeftFraction = (clippedLeft - logicalLeft) / logicalWidth;\n viewport.visibleTopFraction = (clippedTop - logicalTop) / logicalHeight;\n viewport.visibleWidthFraction = clippedWidth / logicalWidth;\n viewport.visibleHeightFraction = clippedHeight / logicalHeight;\n }\n\n // Sets the viewport to the clipped viewport. Any drawing must take\n // `visible{Left,Top,Width,Height}Fraction` into account. setGLClippedViewport() {\n setGLClippedViewport() {\n const {\n gl,\n canvasRelativeClippedTop,\n canvasRelativeClippedLeft,\n renderViewport: { width, height },\n } = this;\n const bottom = canvasRelativeClippedTop + height;\n gl.enable(WebGL2RenderingContext.SCISSOR_TEST);\n const glBottom = this.context.canvas.height - bottom;\n gl.viewport(canvasRelativeClippedLeft, glBottom, width, height);\n gl.scissor(canvasRelativeClippedLeft, glBottom, width, height);\n }\n\n // Sets the viewport to the logical viewport, using the scissor test to constrain drawing to the\n // clipped viewport. Drawing does not need to take `visible{Left,Top,Width,Height}Fraction` into\n // account.\n setGLLogicalViewport() {\n const {\n gl,\n renderViewport: { width, height, logicalWidth, logicalHeight },\n } = this;\n const canvasHeight = this.context.canvas.height;\n gl.enable(WebGL2RenderingContext.SCISSOR_TEST);\n gl.viewport(\n this.canvasRelativeLogicalLeft,\n canvasHeight - (this.canvasRelativeLogicalTop + logicalHeight),\n logicalWidth,\n logicalHeight,\n );\n gl.scissor(\n this.canvasRelativeClippedLeft,\n canvasHeight - (this.canvasRelativeClippedTop + height),\n width,\n height,\n );\n }\n\n abstract draw(): void;\n\n disposed() {\n this.context.unmonitorPanel(this.element, this.monitorState);\n this.context.removePanel(this);\n super.disposed();\n }\n\n get visible() {\n return this.visibility.visible;\n }\n\n getDepthArray(): Float32Array | undefined {\n return undefined;\n }\n\n get shouldDraw() {\n if (!this.visible) return false;\n const { element } = this;\n if (\n element.clientWidth === 0 ||\n element.clientHeight === 0 ||\n element.offsetWidth === 0 ||\n element.offsetHeight === 0\n ) {\n // Skip drawing if the panel has zero client area.\n return false;\n }\n return true;\n }\n\n // Returns a number that determine the order in which panels are drawn. This is used by CdfPanel\n // to ensure it is drawn after other panels that update the histogram.\n //\n // A higher number -> later draw.\n get drawOrder() {\n return 0;\n }\n}\n\nexport abstract class IndirectRenderedPanel extends RenderedPanel {\n canvas = document.createElement(\"canvas\");\n canvasRenderingContext = this.canvas.getContext(\"2d\");\n constructor(\n context: Borrowed,\n element: HTMLElement,\n visibility: WatchableVisibilityPriority,\n ) {\n super(context, element, visibility);\n const { canvas } = this;\n element.appendChild(canvas);\n element.style.position = \"relative\";\n canvas.style.position = \"absolute\";\n canvas.style.left = \"0\";\n canvas.style.right = \"0\";\n canvas.style.top = \"0\";\n canvas.style.bottom = \"0\";\n }\n\n abstract drawIndirect(): void;\n\n draw() {\n this.drawIndirect();\n const { renderViewport, canvas } = this;\n const { logicalWidth, logicalHeight } = renderViewport;\n canvas.width = logicalWidth;\n canvas.height = logicalHeight;\n const { canvasRenderingContext } = this;\n canvasRenderingContext?.drawImage(\n this.context.canvas,\n this.canvasRelativeLogicalLeft,\n this.canvasRelativeLogicalTop,\n logicalWidth,\n logicalHeight,\n 0,\n 0,\n logicalWidth,\n logicalHeight,\n );\n }\n}\n\n// Specifies a rectangular sub-region of the full viewer area to actually be rendered on the canvas.\n// This is used by the Python integration to produce large screenshots by tiling multiple\n// screenshots.\n//\n// The value is: `[left, top, width, height]` where all values are in [0, 1].\nexport class TrackableWindowedViewport extends TrackableValue {\n constructor() {\n super(Float64Array.of(0, 0, 1, 1), (obj) =>\n parseFixedLengthArray(new Float64Array(4), obj, verifyFloat01),\n );\n }\n toJSON() {\n const { value } = this;\n const [left, top, width, height] = value;\n if (left === 0 && top === 0 && width === 1 && height === 1)\n return undefined;\n return Array.from(value);\n }\n}\n\n// Size/position monitoring state for a single panel.\ninterface PanelMonitorState {\n // Intersection observer used to detect movement of a panel. The root element is always the root\n // container element.\n intersectionObserver?: IntersectionObserver;\n\n // Margin within the root element chosen to exactly match the bounds\n // of the panel element when the IntersectionObserver was created.\n // When the bounds of either the root element or the panel element\n // have possibly changed, the new margin is computed and compared to\n // this value. This is stored separately, rather than just relying\n // on `intersectionObserver?.rootMargin`, to avoid spuriously change\n // detections due to normalization that the browser may do.\n intersectionObserverMargin?: string;\n\n // Indicates that the panel element was added to the resize observer.\n addedToResizeObserver?: boolean;\n}\n\nexport class DisplayContext extends RefCounted implements FrameNumberCounter {\n canvas = document.createElement(\"canvas\");\n gl: GL;\n updateStarted = new NullarySignal();\n updateFinished = new NullarySignal();\n continuousCameraMotionStarted = new NullarySignal();\n continuousCameraMotionFinished = new NullarySignal();\n changed = this.updateFinished;\n panels = new Set();\n canvasRect: DOMRect | undefined;\n rootRect: DOMRect | undefined;\n resizeGeneration = 0;\n boundsGeneration = -1;\n private framerateMonitor = new FramerateMonitor();\n\n private continuousCameraMotionInProgress = false;\n\n // Panels ordered by `drawOrder`. If length is 0, needs to be recomputed.\n private orderedPanels: RenderedPanel[] = [];\n\n /**\n * Unique number of the next frame. Incremented once each time a frame is drawn.\n */\n frameNumber = 0;\n\n resizeCallback = () => {\n ++this.resizeGeneration;\n this.scheduleRedraw();\n };\n\n ensureMonitorPanel(\n element: HTMLElement,\n state: PanelMonitorState,\n elementClientRect: DOMRect,\n ) {\n if (!state.addedToResizeObserver) {\n this.resizeObserver.observe(element);\n state.addedToResizeObserver = true;\n }\n const rootRect = this.rootRect!;\n const marginTop = rootRect.top - elementClientRect.top;\n const marginLeft = rootRect.left - elementClientRect.left;\n const marginRight = elementClientRect.right - rootRect.right;\n const marginBottom = elementClientRect.bottom - rootRect.bottom;\n const margin = `${marginTop}px ${marginRight}px ${marginBottom}px ${marginLeft}px`;\n if (state.intersectionObserverMargin !== margin) {\n state.intersectionObserverMargin = margin;\n state.intersectionObserver?.disconnect();\n const intersectionObserver = (state.intersectionObserver =\n new IntersectionObserver(this.resizeCallback, {\n root: this.container,\n rootMargin: margin,\n threshold: [0.93, 0.94, 0.95, 0.96, 0.97, 0.98, 0.99, 1],\n }));\n intersectionObserver.observe(element);\n }\n }\n\n unmonitorPanel(element: HTMLElement, state: PanelMonitorState) {\n if (state.addedToResizeObserver) {\n this.resizeObserver.unobserve(element);\n }\n state.intersectionObserver?.disconnect();\n }\n\n private resizeObserver = new ResizeObserver(this.resizeCallback);\n\n private debouncedEndContinuousCameraMotion = this.registerCancellable(\n debounce(() => {\n this.continuousCameraMotionInProgress = false;\n this.continuousCameraMotionFinished.dispatch();\n }, DELAY_AFTER_CONTINUOUS_CAMERA_MOTION_MS),\n );\n\n flagContinuousCameraMotion() {\n if (!this.continuousCameraMotionInProgress) {\n this.continuousCameraMotionStarted.dispatch();\n }\n this.continuousCameraMotionInProgress = true;\n this.debouncedEndContinuousCameraMotion();\n }\n\n get isContinuousCameraMotionInProgress() {\n return this.continuousCameraMotionInProgress;\n }\n\n constructor(public container: HTMLElement) {\n super();\n const { canvas, resizeObserver } = this;\n container.style.position = \"relative\";\n canvas.style.position = \"absolute\";\n canvas.style.top = \"0px\";\n canvas.style.left = \"0px\";\n canvas.style.width = \"100%\";\n canvas.style.height = \"100%\";\n canvas.style.zIndex = \"0\";\n resizeObserver.observe(canvas);\n container.appendChild(canvas);\n this.registerEventListener(\n canvas,\n \"webglcontextlost\",\n (event: WebGLContextEvent) => {\n console.log(`Lost WebGL context: ${event.statusMessage}`);\n // Wait for context to be regained.\n event.preventDefault();\n },\n );\n this.registerEventListener(canvas, \"webglcontextrestored\", () => {\n console.log(\"WebGL context restored\");\n // Simply reload Neuroglancer.\n window.location.reload();\n });\n this.gl = initializeWebGL(canvas);\n }\n\n applyWindowedViewportToElement(element: HTMLElement, value: Float64Array) {\n // These values specify the position of the canvas relative to the viewer. However, we will\n // actually leave the canvas in place (such that it still fills the browser window) and move\n // the viewer.\n const [left, top, width, height] = value;\n const totalWidth = 1 / width;\n const totalHeight = 1 / height;\n element.style.position = \"absolute\";\n element.style.top = `${-totalHeight * top * 100}%`;\n element.style.left = `${-totalWidth * left * 100}%`;\n element.style.width = `${totalWidth * 100}%`;\n element.style.height = `${totalHeight * 100}%`;\n ++this.resizeGeneration;\n this.scheduleRedraw();\n }\n\n isReady() {\n for (const panel of this.panels) {\n if (!panel.visible) {\n continue;\n }\n if (!panel.isReady()) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * Returns a child element that overlays the canvas.\n */\n makeCanvasOverlayElement() {\n const element = document.createElement(\"div\");\n element.style.position = \"absolute\";\n element.style.top = \"0px\";\n element.style.left = \"0px\";\n element.style.width = \"100%\";\n element.style.height = \"100%\";\n element.style.zIndex = \"2\";\n this.container.appendChild(element);\n return element;\n }\n\n disposed() {\n this.orderedPanels.length = 0;\n this.resizeObserver.disconnect();\n }\n\n addPanel(panel: Borrowed) {\n this.panels.add(panel);\n this.orderedPanels.length = 0;\n ++this.resizeGeneration;\n this.scheduleRedraw();\n }\n\n removePanel(panel: Borrowed) {\n this.panels.delete(panel);\n this.orderedPanels.length = 0;\n ++this.resizeGeneration;\n this.scheduleRedraw();\n }\n\n readonly scheduleRedraw = this.registerCancellable(\n animationFrameDebounce(() => this.draw()),\n );\n\n ensureBoundsUpdated() {\n const { resizeGeneration } = this;\n if (this.boundsGeneration === resizeGeneration) return;\n const { canvas } = this;\n canvas.width = canvas.offsetWidth;\n canvas.height = canvas.offsetHeight;\n this.canvasRect = canvas.getBoundingClientRect();\n this.rootRect = this.container.getBoundingClientRect();\n this.boundsGeneration = resizeGeneration;\n }\n\n draw() {\n ++this.frameNumber;\n this.updateStarted.dispatch();\n const gl = this.gl;\n const ext = this.framerateMonitor.getTimingExtension(gl);\n const query = this.framerateMonitor.startFrameTimeQuery(gl, ext);\n this.ensureBoundsUpdated();\n this.gl.clearColor(0.0, 0.0, 0.0, 0.0);\n gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n const { orderedPanels, panels } = this;\n if (orderedPanels.length !== panels.size) {\n orderedPanels.push(...panels);\n orderedPanels.sort((a, b) => a.drawOrder - b.drawOrder);\n }\n for (const panel of orderedPanels) {\n if (!panel.shouldDraw) continue;\n panel.ensureBoundsUpdated();\n const { renderViewport } = panel;\n if (renderViewport.width === 0 || renderViewport.height === 0) continue;\n panel.draw();\n }\n\n // Ensure the alpha buffer is set to 1.\n gl.disable(gl.SCISSOR_TEST);\n this.gl.clearColor(1.0, 1.0, 1.0, 1.0);\n this.gl.colorMask(false, false, false, true);\n gl.clear(gl.COLOR_BUFFER_BIT);\n this.gl.colorMask(true, true, true, true);\n this.updateFinished.dispatch();\n this.framerateMonitor.endFrameTimeQuery(gl, ext, query);\n this.framerateMonitor.grabAnyFinishedQueryResults(gl);\n }\n\n getDepthArray(): Float32Array {\n const { width, height } = this.canvas;\n const depthArray = new Float32Array(width * height);\n for (const panel of this.panels) {\n if (!panel.shouldDraw) continue;\n const panelDepthArray = panel.getDepthArray();\n if (panelDepthArray === undefined) continue;\n const {\n canvasRelativeClippedTop,\n canvasRelativeClippedLeft,\n renderViewport: { width, height },\n } = panel;\n for (let y = 0; y < height; ++y) {\n const panelDepthArrayOffset = (height - 1 - y) * width;\n depthArray.set(\n panelDepthArray.subarray(\n panelDepthArrayOffset,\n panelDepthArrayOffset + width,\n ),\n (canvasRelativeClippedTop + y) * width + canvasRelativeClippedLeft,\n );\n }\n }\n return depthArray;\n }\n\n getLastFrameTimesInMs(numberOfFrames: number = 10) {\n return this.framerateMonitor.getLastFrameTimesInMs(numberOfFrames);\n }\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { RenderViewport, renderViewportsEqual } from \"#src/display_context.js\";\nimport type { DisplayDimensionRenderInfo } from \"#src/navigation_state.js\";\nimport { arraysEqual } from \"#src/util/array.js\";\nimport { mat4 } from \"#src/util/geom.js\";\nimport { kEmptyFloat32Vec } from \"#src/util/vector.js\";\n\nexport class ProjectionParameters extends RenderViewport {\n displayDimensionRenderInfo: DisplayDimensionRenderInfo;\n\n /**\n * Global position.\n */\n globalPosition: Float32Array = kEmptyFloat32Vec;\n\n /**\n * Transform from camera coordinates to OpenGL clip coordinates.\n */\n projectionMat: mat4 = mat4.create();\n\n /**\n * Transform from world coordinates to camera coordinates.\n */\n viewMatrix: mat4 = mat4.create();\n\n /**\n * Inverse of `viewMat`.\n */\n invViewMatrix: mat4 = mat4.create();\n\n /**\n * Transform from world coordinates to OpenGL clip coordinates. Equal to:\n * `projectionMat * viewMat`.\n */\n viewProjectionMat: mat4 = mat4.create();\n\n /**\n * Inverse of `viewProjectionMat`.\n */\n invViewProjectionMat: mat4 = mat4.create();\n}\n\nexport function projectionParametersEqual(\n a: ProjectionParameters,\n b: ProjectionParameters,\n) {\n return (\n a.displayDimensionRenderInfo === b.displayDimensionRenderInfo &&\n renderViewportsEqual(a, b) &&\n arraysEqual(a.globalPosition, b.globalPosition) &&\n arraysEqual(a.projectionMat, b.projectionMat) &&\n arraysEqual(a.viewMatrix, b.viewMatrix)\n );\n}\n\nexport function updateProjectionParametersFromInverseViewAndProjection(\n p: ProjectionParameters,\n) {\n const { viewMatrix, viewProjectionMat } = p;\n mat4.invert(viewMatrix, p.invViewMatrix);\n mat4.multiply(viewProjectionMat, p.projectionMat, viewMatrix);\n mat4.invert(p.invViewProjectionMat, viewProjectionMat);\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Message list framework for messages to be displayed in the UI.\n */\n\nimport { NullarySignal } from \"#src/util/signal.js\";\n\nexport enum MessageSeverity {\n info = 0,\n warning = 1,\n error = 2,\n}\n\nexport class Message {\n severity: MessageSeverity;\n message: string;\n}\n\nexport class MessageList {\n changed = new NullarySignal();\n\n private messages: Message[] = [];\n private children: MessageList[] = [];\n\n addMessage(message: Message) {\n this.messages.push(message);\n this.changed.dispatch();\n }\n\n clearMessages() {\n const { messages } = this;\n if (messages.length === 0) return;\n messages.length = 0;\n this.changed.dispatch();\n }\n\n isEmpty(): boolean {\n return (\n this.messages.length === 0 && !this.children.some((x) => !x.isEmpty())\n );\n }\n\n addChild(list: MessageList) {\n this.children.push(list);\n list.changed.add(this.changed.dispatch);\n if (!list.isEmpty()) {\n this.changed.dispatch();\n }\n return () => {\n const { children } = this;\n children.splice(children.indexOf(list), 1);\n list.changed.remove(this.changed.dispatch);\n if (!list.isEmpty()) {\n this.changed.dispatch();\n }\n };\n }\n\n *[Symbol.iterator](): Iterator {\n yield* this.messages;\n for (const child of this.children) {\n yield* child;\n }\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { CancellationToken } from \"#src/util/cancellation.js\";\nimport {\n CANCELED,\n CancellationTokenSource,\n makeCancelablePromise,\n uncancelableToken,\n} from \"#src/util/cancellation.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\n\nexport type RPCHandler = (this: RPC, x: any) => void;\n\nexport type RpcId = number;\n\nconst IS_WORKER = !(typeof Window !== \"undefined\" && self instanceof Window);\n\nconst DEBUG = false;\n\nconst DEBUG_MESSAGES = false;\n\nconst PROMISE_RESPONSE_ID = \"rpc.promise.response\";\nconst PROMISE_CANCEL_ID = \"rpc.promise.cancel\";\nconst READY_ID = \"rpc.ready\";\n\nconst handlers = new Map();\n\nexport function registerRPC(key: string, handler: RPCHandler) {\n handlers.set(key, handler);\n}\n\nexport type RPCPromise = Promise<{ value: T; transfers?: any[] }>;\n\nexport class RPCError extends Error {\n constructor(\n public name: string,\n public message: string,\n ) {\n super(message);\n }\n}\n\nexport function registerPromiseRPC(\n key: string,\n handler: (\n this: RPC,\n x: any,\n cancellationToken: CancellationToken,\n ) => RPCPromise,\n) {\n registerRPC(key, function (this: RPC, x: any) {\n const id = x.id;\n const cancellationToken = new CancellationTokenSource();\n const promise = handler.call(this, x, cancellationToken) as RPCPromise;\n this.set(id, { promise, cancellationToken });\n promise.then(\n ({ value, transfers }) => {\n this.delete(id);\n this.invoke(PROMISE_RESPONSE_ID, { id: id, value: value }, transfers);\n },\n (error) => {\n this.delete(id);\n this.invoke(PROMISE_RESPONSE_ID, {\n id: id,\n error: error.message,\n errorName: error.name,\n });\n },\n );\n });\n}\n\nregisterRPC(PROMISE_CANCEL_ID, function (this: RPC, x: any) {\n const id = x.id;\n const request = this.get(id);\n if (request !== undefined) {\n const { cancellationToken } = request;\n cancellationToken.cancel();\n }\n});\n\nregisterRPC(PROMISE_RESPONSE_ID, function (this: RPC, x: any) {\n const id = x.id;\n const { resolve, reject } = this.get(id);\n this.delete(id);\n if (Object.prototype.hasOwnProperty.call(x, \"value\")) {\n resolve(x.value);\n } else {\n const errorName = x.errorName;\n if (errorName === CANCELED.name) {\n reject(CANCELED);\n } else {\n reject(new RPCError(x.errorName, x.error));\n }\n }\n});\n\nregisterRPC(READY_ID, function (this: RPC, x: any) {\n x;\n this.onPeerReady();\n});\n\ninterface RPCTarget {\n postMessage(message?: any, ports?: any): void;\n onmessage: ((ev: MessageEvent) => any) | null;\n}\n\nconst INITIAL_RPC_ID = IS_WORKER ? -1 : 0;\n\nexport class RPC {\n private objects = new Map();\n private nextId: RpcId = INITIAL_RPC_ID;\n private queue: { data: any; transfers?: any[] }[] | undefined;\n constructor(\n public target: RPCTarget,\n waitUntilReady: boolean,\n ) {\n if (waitUntilReady) {\n this.queue = [];\n }\n target.onmessage = (e) => {\n const data = e.data;\n if (DEBUG_MESSAGES) {\n console.log(\"Received message\", data);\n }\n handlers.get(data.functionName)!.call(this, data);\n };\n }\n\n sendReady() {\n this.invoke(READY_ID, {});\n }\n\n onPeerReady() {\n const { queue } = this;\n if (queue === undefined) return;\n this.queue = undefined;\n for (const { data, transfers } of queue) {\n this.target.postMessage(data, transfers);\n }\n }\n\n get numObjects() {\n return this.objects.size;\n }\n\n set(id: RpcId, value: any) {\n this.objects.set(id, value);\n }\n\n delete(id: RpcId) {\n this.objects.delete(id);\n }\n get(id: RpcId) {\n return this.objects.get(id);\n }\n getRef(x: { id: RpcId; gen: number }): T {\n const rpcId = x.id;\n const obj = this.get(rpcId);\n obj.referencedGeneration = x.gen;\n obj.addRef();\n return obj;\n }\n\n getOptionalRef(x: {\n id: RpcId;\n gen: number;\n }): T | undefined {\n if (x === undefined) return undefined;\n const rpcId = x.id;\n const obj = this.get(rpcId) as T;\n obj.referencedGeneration = x.gen;\n obj.addRef();\n return obj;\n }\n\n invoke(name: string, x: any, transfers?: any[]) {\n x.functionName = name;\n if (DEBUG_MESSAGES) {\n console.trace(\"Sending message\", x);\n }\n const { queue } = this;\n if (queue !== undefined) {\n queue.push({ data: x, transfers });\n return;\n }\n this.target.postMessage(x, transfers);\n }\n\n promiseInvoke(\n name: string,\n x: any,\n cancellationToken = uncancelableToken,\n transfers?: any[],\n ): Promise {\n return makeCancelablePromise(\n cancellationToken,\n (resolve, reject, token) => {\n const id = (x.id = this.newId());\n this.set(id, { resolve, reject });\n this.invoke(name, x, transfers);\n token.add(() => {\n this.invoke(PROMISE_CANCEL_ID, { id: id });\n });\n },\n );\n }\n newId() {\n return IS_WORKER ? this.nextId-- : this.nextId++;\n }\n}\n\nexport class SharedObject extends RefCounted {\n rpc: RPC | null = null;\n rpcId: RpcId | null = null;\n isOwner: boolean | undefined;\n unreferencedGeneration: number;\n referencedGeneration: number;\n\n initializeSharedObject(rpc: RPC, rpcId = rpc.newId()) {\n this.rpc = rpc;\n this.rpcId = rpcId;\n this.isOwner = false;\n rpc.set(rpcId, this);\n }\n\n initializeCounterpart(rpc: RPC, options: any = {}) {\n this.initializeSharedObject(rpc);\n this.unreferencedGeneration = 0;\n this.referencedGeneration = 0;\n this.isOwner = true;\n options.id = this.rpcId;\n options.type = this.RPC_TYPE_ID;\n rpc.invoke(\"SharedObject.new\", options);\n }\n\n dispose() {\n super.dispose();\n }\n\n /**\n * Precondition: this.isOwner === true.\n */\n addCounterpartRef() {\n return { id: this.rpcId, gen: ++this.referencedGeneration };\n }\n\n protected refCountReachedZero() {\n if (this.isOwner === true) {\n if (this.referencedGeneration === this.unreferencedGeneration) {\n this.ownerDispose();\n }\n } else if (this.isOwner === false) {\n this.rpc!.invoke(\"SharedObject.refCountReachedZero\", {\n id: this.rpcId,\n gen: this.referencedGeneration,\n });\n } else {\n super.refCountReachedZero();\n }\n }\n\n /**\n * Precondition: this.isOwner === true.\n */\n protected ownerDispose() {\n if (DEBUG) {\n console.log(`[${IS_WORKER}] #rpc object = ${this.rpc!.numObjects}`);\n }\n const { rpc, rpcId } = this;\n super.refCountReachedZero();\n rpc!.delete(rpcId!);\n rpc!.invoke(\"SharedObject.dispose\", { id: rpcId });\n }\n\n /**\n * Precondition: this.isOwner === true.\n *\n * This should be called when the counterpart's refCount is decremented and reaches zero.\n */\n counterpartRefCountReachedZero(generation: number) {\n this.unreferencedGeneration = generation;\n if (this.refCount === 0 && generation === this.referencedGeneration) {\n this.ownerDispose();\n }\n }\n\n /**\n * Should be set to a constant specifying the SharedObject type identifier on the prototype of\n * final derived owner classes. It is not used on counterpart (non-owner) classes.\n */\n RPC_TYPE_ID: string;\n}\n\nexport function initializeSharedObjectCounterpart(\n obj: SharedObject,\n rpc?: RPC,\n options: any = {},\n) {\n if (rpc != null) {\n obj.initializeSharedObject(rpc, options.id);\n }\n}\n\n/**\n * Base class for defining a SharedObject type that will never be owned.\n */\nexport class SharedObjectCounterpart extends SharedObject {\n constructor(rpc?: RPC, options: any = {}) {\n super();\n initializeSharedObjectCounterpart(this, rpc, options);\n }\n}\n\nexport interface SharedObjectConstructor {\n new (rpc: RPC, options: any): SharedObjectCounterpart;\n}\n\nregisterRPC(\"SharedObject.dispose\", function (x) {\n const obj = this.get(x.id);\n if (obj.refCount !== 0) {\n throw new Error(\n \"Attempted to dispose object with non-zero reference count.\",\n );\n }\n if (DEBUG) {\n console.log(`[${IS_WORKER}] #rpc objects: ${this.numObjects}`);\n }\n obj.disposed();\n this.delete(obj.rpcId!);\n obj.rpcId = null;\n obj.rpc = null;\n});\n\nregisterRPC(\"SharedObject.refCountReachedZero\", function (x) {\n const obj = this.get(x.id);\n const generation = x.gen;\n obj.counterpartRefCountReachedZero(generation);\n});\n\nconst sharedObjectConstructors = new Map();\n\n/**\n * Register a class as a SharedObject owner type under the specified identifier.\n *\n * This is intended to be used as a decorator.\n */\nexport function registerSharedObjectOwner(identifier: string) {\n return (constructorFunction: { prototype: { RPC_TYPE_ID: string } }) => {\n constructorFunction.prototype.RPC_TYPE_ID = identifier;\n };\n}\n\n/**\n * Register a class as a SharedObject counterpart type under the specified identifier.\n *\n * This is intended to be used as a decorator.\n *\n * Also register the type as a SharedObject owner, which is useful if this type is also used as a\n * SharedObject owner.\n */\nexport function registerSharedObject(identifier?: string) {\n return (constructorFunction: SharedObjectConstructor) => {\n if (identifier !== undefined) {\n constructorFunction.prototype.RPC_TYPE_ID = identifier;\n } else {\n identifier = constructorFunction.prototype.RPC_TYPE_ID;\n if (identifier === undefined) {\n throw new Error(\"RPC_TYPE_ID should have already been defined\");\n }\n }\n sharedObjectConstructors.set(identifier, constructorFunction);\n };\n}\n\nregisterRPC(\"SharedObject.new\", function (x) {\n const rpc = this;\n const typeName = x.type;\n const constructorFunction = sharedObjectConstructors.get(typeName)!;\n const obj = new constructorFunction(rpc, x);\n // Counterpart objects start with a reference count of zero.\n --obj.refCount;\n});\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Facility for sharing arbitrary values that support structural cloning between threads.\n */\n\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { WatchableValue } from \"#src/trackable_value.js\";\nimport type { RPC } from \"#src/worker_rpc.js\";\nimport {\n registerRPC,\n registerSharedObject,\n SharedObjectCounterpart,\n} from \"#src/worker_rpc.js\";\n\nconst CHANGED_RPC_METHOD_ID = \"SharedWatchableValue.changed\";\n\n@registerSharedObject(\"SharedWatchableValue\")\nexport class SharedWatchableValue\n extends SharedObjectCounterpart\n implements WatchableValueInterface\n{\n base: WatchableValueInterface;\n\n /**\n * The value is being updated to reflect a remote change.\n * @internal\n */\n updatingValue_ = false;\n\n constructor(rpc?: RPC, options: any = {}) {\n super(rpc, options);\n if (rpc !== undefined) {\n this.base = new WatchableValue(options.value);\n this.setupChangedHandler();\n }\n }\n\n initializeCounterpart(rpc: RPC, options: any = {}) {\n options.value = this.value;\n super.initializeCounterpart(rpc, options);\n }\n\n private setupChangedHandler() {\n this.registerDisposer(\n this.base.changed.add(() => {\n if (this.updatingValue_) {\n this.updatingValue_ = false;\n } else {\n const { rpc } = this;\n if (rpc !== null) {\n rpc.invoke(CHANGED_RPC_METHOD_ID, {\n id: this.rpcId,\n value: this.value,\n });\n }\n }\n }),\n );\n }\n\n static makeFromExisting(rpc: RPC, base: WatchableValueInterface) {\n const obj = new SharedWatchableValue();\n obj.base = base;\n obj.setupChangedHandler();\n obj.initializeCounterpart(rpc);\n return obj;\n }\n\n static make(rpc: RPC, value: T) {\n return SharedWatchableValue.makeFromExisting(\n rpc,\n new WatchableValue(value),\n );\n }\n\n get value() {\n return this.base.value;\n }\n\n set value(value: T) {\n this.base.value = value;\n }\n\n get changed() {\n return this.base.changed;\n }\n}\n\nregisterRPC(CHANGED_RPC_METHOD_ID, function (x) {\n const obj = >this.get(x.id);\n obj.updatingValue_ = true;\n obj.base.value = x.value;\n obj.updatingValue_ = false;\n});\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { SharedWatchableValue } from \"#src/shared_watchable_value.js\";\nimport { WatchableValue } from \"#src/trackable_value.js\";\nimport type { RPC, SharedObject } from \"#src/worker_rpc.js\";\n\n/**\n * Numeric value specifying a visibility or prefetch priority.\n *\n * A value of `Number.POSITIVE_INFINITY` means visible.\n *\n * Any other finite value means not visible, and specifies the prefetch priority (higher means\n * higher priority); this should always be a small integer.\n *\n * A value of `Number.NEGATIVE_INFINITY` means ignored (not visible, and not prefetched).\n */\nexport type VisibilityPriority = number;\n\nexport class WatchableVisibilityPriority extends WatchableValue {\n // biome-ignore lint/complexity/noUselessConstructor: adds defaults\n constructor(value = Number.NEGATIVE_INFINITY) {\n super(value);\n }\n\n static VISIBLE = Number.POSITIVE_INFINITY;\n static IGNORED = Number.NEGATIVE_INFINITY;\n get visible() {\n return this.value === Number.POSITIVE_INFINITY;\n }\n\n get ignored() {\n return this.value === Number.NEGATIVE_INFINITY;\n }\n}\n\nexport interface VisibilityPrioritySpecification {\n visibility: WatchableVisibilityPriority;\n}\n\n/**\n * Maintains the maximum value of multiple WatchableVisibilityPriority values.\n */\nexport class VisibilityPriorityAggregator extends WatchableVisibilityPriority {\n private contributors = new Map<() => void, WatchableVisibilityPriority>();\n\n /**\n * Registers `x` to be included in the set of values to be aggregated.\n *\n * @returns A disposer function that unregisters the specified value.\n */\n add(x: WatchableVisibilityPriority) {\n const { contributors } = this;\n const changedDisposer = x.changed.add(() => {\n this.update();\n });\n const disposer = () => {\n contributors.delete(disposer);\n changedDisposer();\n this.update();\n };\n contributors.set(disposer, x);\n this.update();\n return disposer;\n }\n\n private update() {\n let priority = Number.NEGATIVE_INFINITY;\n for (const x of this.contributors.values()) {\n priority = Math.max(priority, x.value);\n }\n this.value = priority;\n }\n}\n\n/**\n * Mixin that adds a `visibility` property which is shared with the counterpart.\n */\nexport function withSharedVisibility<\n T extends { new (...args: any[]): SharedObject },\n>(Base: T) {\n return class extends Base {\n visibility = new VisibilityPriorityAggregator();\n\n initializeCounterpart(rpc: RPC, options: any = {}) {\n // Backend doesn't need to own a reference to SharedWatchableValue because frontend, which is\n // the owner of this SharedObject, owns a reference.\n options.visibility = this.registerDisposer(\n SharedWatchableValue.makeFromExisting(rpc, this.visibility),\n ).rpcId;\n super.initializeCounterpart(rpc, options);\n }\n };\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { debounce } from \"lodash-es\";\nimport { LayerChunkProgressInfo } from \"#src/chunk_manager/base.js\";\nimport { RenderViewport, renderViewportsEqual } from \"#src/display_context.js\";\nimport type {\n LayerView,\n MouseSelectionState,\n PickState,\n UserLayer,\n VisibleLayerInfo,\n} from \"#src/layer/index.js\";\nimport type {\n DisplayDimensionRenderInfo,\n NavigationState,\n} from \"#src/navigation_state.js\";\nimport type { PickIDManager } from \"#src/object_picking.js\";\nimport {\n ProjectionParameters,\n projectionParametersEqual,\n} from \"#src/projection_parameters.js\";\nimport type { RenderLayerTransformOrError } from \"#src/render_coordinate_transform.js\";\nimport { get3dModelToDisplaySpaceMatrix } from \"#src/render_coordinate_transform.js\";\nimport {\n PROJECTION_PARAMETERS_CHANGED_RPC_METHOD_ID,\n PROJECTION_PARAMETERS_RPC_ID,\n} from \"#src/render_layer_common.js\";\nimport type { WatchableValueChangeInterface } from \"#src/trackable_value.js\";\nimport { WatchableSet } from \"#src/trackable_value.js\";\nimport type { Borrowed } from \"#src/util/disposable.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { mat4 } from \"#src/util/geom.js\";\nimport { MessageList, MessageSeverity } from \"#src/util/message_list.js\";\nimport { NullarySignal, Signal } from \"#src/util/signal.js\";\nimport type { Uint64 } from \"#src/util/uint64.js\";\nimport { VisibilityPriorityAggregator } from \"#src/visibility_priority/frontend.js\";\nimport type { RPC } from \"#src/worker_rpc.js\";\nimport { registerSharedObjectOwner, SharedObject } from \"#src/worker_rpc.js\";\n\nexport enum RenderLayerRole {\n DATA = 0,\n ANNOTATION = 1,\n DEFAULT_ANNOTATION = 2,\n}\n\nexport function allRenderLayerRoles() {\n return new WatchableSet([\n RenderLayerRole.DATA,\n RenderLayerRole.ANNOTATION,\n RenderLayerRole.DEFAULT_ANNOTATION,\n ]);\n}\n\nexport class RenderLayer extends RefCounted {\n userLayer: UserLayer | undefined;\n role: RenderLayerRole = RenderLayerRole.DATA;\n messages = new MessageList();\n layerChanged = new NullarySignal();\n redrawNeeded = new NullarySignal();\n layerChunkProgressInfo = new LayerChunkProgressInfo();\n\n handleAction(_action: string) {\n // Do nothing by default.\n }\n\n getValueAt(_x: Float32Array): any {\n return undefined;\n }\n\n /**\n * Transform the stored pickedValue and offset associated with the retrieved pick ID into the\n * actual value.\n */\n transformPickedValue(pickState: PickState): any {\n return pickState.pickedValue;\n }\n\n /**\n * Optionally updates the mouse state based on the retrived pick information. This might snap the\n * 3-d position to the center of the picked point.\n */\n updateMouseState(\n _mouseState: MouseSelectionState,\n _pickedValue: Uint64,\n _pickedOffset: number,\n _data: any,\n ) {}\n}\n\n/**\n * Extends RenderLayer with functionality for tracking the number of panels in which the layer is\n * visible.\n */\nexport class VisibilityTrackedRenderLayer<\n View extends LayerView = LayerView,\n AttachmentState = unknown,\n> extends RenderLayer {\n backend: SharedObject | undefined;\n visibility = new VisibilityPriorityAggregator();\n attach(attachment: VisibleLayerInfo) {\n attachment;\n }\n}\n\nexport interface ThreeDimensionalReadyRenderContext {\n projectionParameters: ProjectionParameters;\n}\n\nexport interface ThreeDimensionalRenderContext\n extends ThreeDimensionalReadyRenderContext {\n pickIDs: PickIDManager;\n wireFrame: boolean;\n bindFramebuffer: () => void;\n frameNumber: number;\n}\n\nexport interface ThreeDimensionalRenderLayerAttachmentState {\n transform: RenderLayerTransformOrError;\n displayDimensionRenderInfo: DisplayDimensionRenderInfo;\n modelTransform: mat4 | undefined;\n}\n\nexport function update3dRenderLayerAttachment(\n transform: RenderLayerTransformOrError,\n displayDimensionRenderInfo: DisplayDimensionRenderInfo,\n attachment: VisibleLayerInfo<\n LayerView,\n ThreeDimensionalRenderLayerAttachmentState\n >,\n): mat4 | undefined {\n let { state } = attachment;\n if (\n state === undefined ||\n state.transform !== transform ||\n state.displayDimensionRenderInfo !== displayDimensionRenderInfo\n ) {\n attachment.messages.clearMessages();\n state = attachment.state = {\n transform,\n displayDimensionRenderInfo,\n modelTransform: undefined,\n };\n if (transform.error !== undefined) {\n attachment.messages.addMessage({\n severity: MessageSeverity.error,\n message: transform.error,\n });\n return undefined;\n }\n try {\n const modelTransform = mat4.create();\n get3dModelToDisplaySpaceMatrix(\n modelTransform,\n displayDimensionRenderInfo,\n transform,\n );\n state.modelTransform = modelTransform;\n } catch (e) {\n attachment.messages.addMessage({\n severity: MessageSeverity.error,\n message: (e as Error).message,\n });\n }\n }\n return state.modelTransform;\n}\n\nexport class DerivedProjectionParameters<\n Parameters extends ProjectionParameters = ProjectionParameters,\n >\n extends RefCounted\n implements WatchableValueChangeInterface\n{\n private oldValue_: Parameters;\n private value_: Parameters;\n private renderViewport = new RenderViewport();\n\n changed = new Signal<(oldValue: Parameters, newValue: Parameters) => void>();\n constructor(options: {\n navigationState: Borrowed;\n update: (out: Parameters, navigationState: NavigationState) => void;\n isEqual?: (a: Parameters, b: Parameters) => boolean;\n parametersConstructor?: { new (): Parameters };\n }) {\n super();\n const {\n parametersConstructor = ProjectionParameters as { new (): Parameters },\n navigationState,\n update,\n isEqual = projectionParametersEqual,\n } = options;\n this.oldValue_ = new parametersConstructor();\n this.value_ = new parametersConstructor();\n const performUpdate = () => {\n const { oldValue_, value_ } = this;\n oldValue_.displayDimensionRenderInfo =\n navigationState.displayDimensionRenderInfo.value;\n Object.assign(oldValue_, this.renderViewport);\n let { globalPosition } = oldValue_;\n const newGlobalPosition = navigationState.position.value;\n const rank = newGlobalPosition.length;\n if (globalPosition.length !== rank) {\n oldValue_.globalPosition = globalPosition = new Float32Array(rank);\n }\n globalPosition.set(newGlobalPosition);\n update(oldValue_, navigationState);\n if (isEqual(oldValue_, value_)) return;\n this.value_ = oldValue_;\n this.oldValue_ = value_;\n this.changed.dispatch(value_, oldValue_);\n };\n const debouncedUpdate = (this.update = this.registerCancellable(\n debounce(performUpdate, 0),\n ));\n this.registerDisposer(navigationState.changed.add(debouncedUpdate));\n performUpdate();\n }\n\n setViewport(viewport: RenderViewport) {\n if (renderViewportsEqual(viewport, this.renderViewport)) return;\n Object.assign(this.renderViewport, viewport);\n this.update();\n }\n\n get value() {\n this.update.flush();\n return this.value_;\n }\n\n readonly update: (() => void) & { flush(): void };\n}\n\n@registerSharedObjectOwner(PROJECTION_PARAMETERS_RPC_ID)\nexport class SharedProjectionParameters<\n T extends ProjectionParameters = ProjectionParameters,\n> extends SharedObject {\n private prevDisplayDimensionRenderInfo:\n | undefined\n | DisplayDimensionRenderInfo = undefined;\n constructor(\n rpc: RPC,\n public base: WatchableValueChangeInterface,\n public updateInterval = 10,\n ) {\n super();\n this.initializeCounterpart(rpc, { value: base.value });\n this.registerDisposer(base.changed.add(this.update));\n }\n\n flush() {\n this.update.flush();\n }\n\n private update = this.registerCancellable(\n debounce((_oldValue: T, newValue: T) => {\n // Note: Because we are using debouce, we cannot rely on `_oldValue`, since\n // `DerivedProjectionParameters` reuses the objects.\n let valueUpdate: any;\n if (\n newValue.displayDimensionRenderInfo !==\n this.prevDisplayDimensionRenderInfo\n ) {\n valueUpdate = newValue;\n this.prevDisplayDimensionRenderInfo =\n newValue.displayDimensionRenderInfo;\n } else {\n const { displayDimensionRenderInfo, ...remainder } = newValue;\n valueUpdate = remainder;\n }\n this.rpc!.invoke(PROJECTION_PARAMETERS_CHANGED_RPC_METHOD_ID, {\n id: this.rpcId,\n value: valueUpdate,\n });\n }, this.updateInterval),\n );\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { debounce } from \"lodash-es\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport type { Trackable } from \"#src/util/trackable.js\";\n\nexport class TrackableBoolean implements Trackable {\n get value() {\n return this.value_;\n }\n set value(newValue: boolean) {\n if (newValue !== this.value_) {\n this.value_ = newValue;\n this.changed.dispatch();\n }\n }\n toggle() {\n this.value = !this.value;\n }\n changed = new NullarySignal();\n constructor(\n private value_: boolean,\n public defaultValue: boolean = value_,\n ) {}\n toJSON() {\n const { value_ } = this;\n if (value_ === this.defaultValue) {\n return undefined;\n }\n return this.value_;\n }\n restoreState(x: any) {\n if (x === true || x === false) {\n this.value = x;\n return;\n }\n this.value = this.defaultValue;\n }\n reset() {\n this.value = this.defaultValue;\n }\n}\n\nexport class TrackableBooleanCheckbox extends RefCounted {\n element = document.createElement(\"input\");\n constructor(\n public model: WatchableValueInterface,\n options: {\n enableTitle?: string;\n disableTitle?: string;\n } = {},\n ) {\n super();\n const { element } = this;\n element.type = \"checkbox\";\n\n const updateCheckbox = () => {\n const value = this.model.value;\n this.element.checked = value;\n if (\n options.enableTitle !== undefined ||\n options.disableTitle !== undefined\n ) {\n this.element.title =\n (value ? options.enableTitle : options.disableTitle) ?? \"\";\n }\n };\n\n this.registerDisposer(model.changed.add(updateCheckbox));\n updateCheckbox();\n this.registerEventListener(\n element,\n \"change\",\n function (this: typeof element, _e: Event) {\n model.value = this.checked;\n },\n );\n\n // Prevent the checkbox from becoming focused.\n element.addEventListener(\"mousedown\", (event: MouseEvent) => {\n event.preventDefault();\n });\n }\n\n disposed() {\n const { element } = this;\n const { parentElement } = element;\n if (parentElement) {\n parentElement.removeChild(element);\n }\n super.disposed();\n }\n}\n\nexport class ElementVisibilityFromTrackableBoolean extends RefCounted {\n private initialDisplay = this.element.style.display;\n constructor(\n public model: WatchableValueInterface,\n public element: HTMLElement,\n ) {\n super();\n this.updateVisibility();\n this.registerDisposer(\n model.changed.add(\n this.registerCancellable(debounce(() => this.updateVisibility(), 0)),\n ),\n );\n }\n\n updateVisibility() {\n this.element.style.display = this.model.value\n ? this.initialDisplay\n : \"none\";\n }\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport type ValueOrError = (T & { error?: undefined }) | { error: string };\n\nexport function makeValueOrError(f: () => T): ValueOrError {\n try {\n return f() as ValueOrError;\n } catch (e) {\n return { error: (e as Error).message };\n }\n}\n\nexport function valueOrThrow(x: ValueOrError): T {\n if (x.error !== undefined) throw new Error(x.error);\n return x;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\n\nexport class WatchableMap extends RefCounted {\n changed = new NullarySignal();\n map: Map;\n private disposerMap = new Map();\n constructor(\n private register: (context: RefCounted, v: V, k: K) => void,\n values?: Iterable<[K, V]>,\n ) {\n super();\n if (values === undefined) {\n this.map = new Map();\n } else {\n const map = (this.map = new Map(values));\n const { disposerMap } = this;\n for (const [key, value] of map) {\n const context = new RefCounted();\n disposerMap.set(key, context);\n register(context, value, key);\n }\n }\n }\n\n get value(): ReadonlyMap {\n return this.map;\n }\n\n set(key: K, value: V) {\n const { map, disposerMap } = this;\n let context = disposerMap.get(key);\n if (context !== undefined) {\n context.dispose();\n }\n context = new RefCounted();\n disposerMap.set(key, context);\n map.set(key, value);\n this.register(context, value, key);\n this.changed.dispatch();\n return this;\n }\n delete(key: K) {\n const { map, disposerMap } = this;\n const context = disposerMap.get(key);\n if (context !== undefined) {\n context.dispose();\n disposerMap.delete(key);\n map.delete(key);\n this.changed.dispatch();\n return true;\n }\n return false;\n }\n get(key: K) {\n return this.map.get(key);\n }\n has(key: K) {\n return this.map.has(key);\n }\n get size() {\n return this.map.size;\n }\n [Symbol.iterator]() {\n return this.map[Symbol.iterator]();\n }\n clear() {\n const { map, disposerMap } = this;\n if (map.size > 0) {\n for (const disposer of disposerMap.values()) {\n disposer.dispose();\n }\n map.clear();\n disposerMap.clear();\n this.changed.dispatch();\n }\n }\n values() {\n return this.map.values();\n }\n keys() {\n return this.map.keys();\n }\n disposed() {\n const { map, disposerMap } = this;\n for (const disposer of disposerMap.values()) {\n disposer.dispose();\n }\n map.clear();\n disposerMap.clear();\n super.disposed();\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nconst OBJECT_ID_SYMBOL = Symbol(\"objectId\");\nlet nextObjectId = 0;\n\n/**\n * Returns a string that uniquely identifies a particular primitive value or object instance.\n */\nexport function getObjectId(x: any) {\n if (x instanceof Object) {\n let id = x[OBJECT_ID_SYMBOL];\n if (id === undefined) {\n id = x[OBJECT_ID_SYMBOL] = nextObjectId++;\n }\n return `o${id}`;\n }\n return \"\" + JSON.stringify(x);\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { DataType } from \"#src/util/data_type.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type {\n ControlPointTexture,\n SortedControlPoints,\n} from \"#src/widget/transfer_function.js\";\n\nconst DEBUG_SHADER = false;\n\nexport enum ShaderType {\n VERTEX = WebGL2RenderingContext.VERTEX_SHADER,\n FRAGMENT = WebGL2RenderingContext.FRAGMENT_SHADER,\n}\n\nexport interface ShaderErrorMessage {\n file?: number;\n line?: number;\n message: string;\n}\n\n/**\n * Parses the output of getShaderInfoLog into a list of messages.\n */\nexport function parseShaderErrors(log: string) {\n log = log.replace(\"\\0\", \"\");\n const result: ShaderErrorMessage[] = [];\n for (let line of log.split(\"\\n\")) {\n let m = line.match(/^ERROR:\\s*(\\d+):(\\d+)\\s*(.+)$/);\n if (m !== null) {\n result.push({\n message: m[3].trim(),\n file: parseInt(m[1], 10),\n line: parseInt(m[2], 10),\n });\n } else {\n m = line.match(/^ERROR:\\s*(.+)$/);\n if (m !== null) {\n result.push({ message: m[1] });\n } else {\n line = line.trim();\n if (line) {\n result.push({ message: line });\n }\n }\n }\n }\n return result;\n}\n\nexport class ShaderCompilationError extends Error {\n shaderType: ShaderType;\n source: string;\n log: string;\n errorMessages: ShaderErrorMessage[];\n constructor(\n shaderType: ShaderType,\n source: string,\n log: string,\n errorMessages: ShaderErrorMessage[],\n ) {\n const message = `Error compiling ${ShaderType[\n shaderType\n ].toLowerCase()} shader: ${log}`;\n super(message);\n this.name = \"ShaderCompilationError\";\n this.log = log;\n this.message = message;\n this.shaderType = shaderType;\n this.source = source;\n this.errorMessages = errorMessages;\n }\n}\n\nexport class ShaderLinkError extends Error {\n vertexSource: string;\n fragmentSource: string;\n log: string;\n constructor(vertexSource: string, fragmentSource: string, log: string) {\n const message = `Error linking shader: ${log}`;\n super(message);\n this.name = \"ShaderLinkError\";\n this.log = log;\n this.message = message;\n this.vertexSource = vertexSource;\n this.fragmentSource = fragmentSource;\n }\n}\n\nexport function getShader(\n gl: WebGL2RenderingContext,\n source: string,\n shaderType: ShaderType,\n) {\n const shader = gl.createShader(shaderType)!;\n gl.shaderSource(shader, source);\n gl.compileShader(shader);\n\n if (!gl.getShaderParameter(shader, gl.COMPILE_STATUS)) {\n const log = gl.getShaderInfoLog(shader) || \"\";\n\n if (DEBUG_SHADER) {\n const lines = source\n .replace(\"<\", \"<\")\n .replace(\">\", \">\")\n .split(\"\\n\");\n let s = \"
\";\n      s += log.replace(\"<\", \"<\").replace(\">\", \">\") + \"\\n\";\n      lines.forEach((line, i) => {\n        s += `${i + 1}: ${line}\\n`;\n      });\n      s += \"\\n
\";\n console.log(s);\n const w = window.open(\"about:blank\", \"_blank\");\n if (w !== null) {\n try {\n w.document.write(s);\n } catch {\n // Ignore error writing output, e.g. due to popup blocking.\n }\n }\n }\n\n throw new ShaderCompilationError(\n shaderType,\n source,\n log,\n parseShaderErrors(log),\n );\n }\n\n return shader!;\n}\n\nexport type AttributeIndex = number;\n\nexport type AttributeType = number;\n\nexport interface VertexShaderInputBinder {\n enable(divisor: number): void;\n disable(): void;\n bind(stride: number, offset: number): void;\n}\n\nlet curShader: ShaderProgram | undefined;\n\nexport class ShaderProgram extends RefCounted {\n program: WebGLProgram;\n vertexShader: WebGLShader;\n fragmentShader: WebGLShader;\n attributes = new Map();\n uniforms = new Map();\n textureUnits: Map;\n vertexShaderInputBinders: { [name: string]: VertexShaderInputBinder } = {};\n vertexDebugOutputs?: VertexDebugOutput[];\n transferFunctionTextures: Map = new Map<\n any,\n ControlPointTexture\n >();\n\n constructor(\n public gl: GL,\n public vertexSource: string,\n public fragmentSource: string,\n uniformNames?: string[],\n attributeNames?: string[],\n vertexDebugOutputs?: VertexDebugOutput[],\n ) {\n super();\n const vertexShader = (this.vertexShader = getShader(\n gl,\n vertexSource,\n gl.VERTEX_SHADER,\n ));\n const fragmentShader = (this.fragmentShader = getShader(\n gl,\n fragmentSource,\n gl.FRAGMENT_SHADER,\n ));\n\n const shaderProgram = gl.createProgram()!;\n gl.attachShader(shaderProgram, vertexShader);\n gl.attachShader(shaderProgram, fragmentShader);\n\n if (DEBUG_SHADER && vertexDebugOutputs?.length) {\n gl.transformFeedbackVaryings(\n shaderProgram,\n vertexDebugOutputs.map((x) => x.name),\n WebGL2RenderingContext.INTERLEAVED_ATTRIBS,\n );\n this.vertexDebugOutputs = vertexDebugOutputs;\n }\n\n gl.linkProgram(shaderProgram);\n if (!gl.getProgramParameter(shaderProgram, gl.LINK_STATUS)) {\n const log = gl.getProgramInfoLog(shaderProgram) || \"\";\n\n // DEBUG\n // {\n // let combinedSource = 'VERTEX SHADER\\n\\n' + vertexSource + '\\n\\n\\nFRAGMENT SHADER\\n\\n' +\n // fragmentSource + '\\n';\n // let w = window.open(\"about:blank\", \"_blank\");\n // w.document.write('
' + combinedSource.replace('<', '<').replace('>', '>') +\n      //   '
');\n // }\n\n throw new ShaderLinkError(vertexSource, fragmentSource, log);\n }\n this.program = shaderProgram!;\n\n const { uniforms, attributes } = this;\n if (uniformNames) {\n for (const name of uniformNames) {\n uniforms.set(name, gl.getUniformLocation(shaderProgram, name));\n }\n }\n\n if (attributeNames) {\n for (const name of attributeNames) {\n attributes.set(name, gl.getAttribLocation(shaderProgram, name));\n }\n }\n }\n\n uniform(name: string): WebGLUniformLocation {\n return this.uniforms.get(name)!;\n }\n\n attribute(name: string): number {\n return this.attributes.get(name)!;\n }\n\n textureUnit(symbol: symbol | string): number {\n return this.textureUnits.get(symbol)!;\n }\n\n bind() {\n curShader = this;\n this.gl.useProgram(this.program);\n }\n\n bindAndUpdateTransferFunctionTexture(\n symbol: symbol | string,\n sortedControlPoints: SortedControlPoints,\n dataType: DataType,\n lookupTableSize: number,\n ) {\n const textureUnit = this.textureUnits.get(symbol);\n if (textureUnit === undefined) {\n throw new Error(`Invalid texture unit symbol: ${symbol.toString()}`);\n }\n const texture = this.transferFunctionTextures.get(symbol);\n if (texture === undefined) {\n throw new Error(\n `Invalid transfer function texture symbol: ${symbol.toString()}`,\n );\n }\n return texture.updateAndActivate({\n textureUnit,\n sortedControlPoints,\n dataType,\n lookupTableSize,\n });\n }\n\n unbindTransferFunctionTextures() {\n const gl = this.gl;\n for (const key of this.transferFunctionTextures.keys()) {\n const value = this.textureUnits.get(key);\n if (value !== undefined) {\n this.gl.activeTexture(gl.TEXTURE0 + value);\n this.gl.bindTexture(gl.TEXTURE_2D, null);\n }\n }\n }\n\n disposed() {\n const { gl } = this;\n gl.deleteShader(this.vertexShader);\n this.vertexShader = undefined;\n gl.deleteShader(this.fragmentShader);\n this.fragmentShader = undefined;\n gl.deleteProgram(this.program);\n this.program = undefined;\n this.gl = undefined;\n this.attributes = undefined;\n this.uniforms = undefined;\n this.transferFunctionTextures = undefined;\n }\n}\n\nexport function drawArraysInstanced(\n gl: WebGL2RenderingContext,\n mode: number,\n first: number,\n count: number,\n instanceCount: number,\n) {\n gl.drawArraysInstanced(mode, first, count, instanceCount);\n if (!DEBUG_SHADER || !curShader?.vertexDebugOutputs) {\n return;\n }\n\n const { vertexDebugOutputs } = curShader;\n let bytesPerVertex = 0;\n for (const debugOutput of vertexDebugOutputs) {\n bytesPerVertex += DEBUG_OUTPUT_TYPE_TO_BYTES[debugOutput.typeName];\n }\n const buffer = gl.createBuffer();\n const totalBytes = bytesPerVertex * count * instanceCount;\n gl.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER, buffer);\n gl.bufferData(\n WebGL2RenderingContext.ARRAY_BUFFER,\n totalBytes,\n WebGL2RenderingContext.DYNAMIC_DRAW,\n );\n gl.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER, null);\n gl.bindBufferBase(\n WebGL2RenderingContext.TRANSFORM_FEEDBACK_BUFFER,\n 0,\n buffer,\n );\n gl.beginTransformFeedback(WebGL2RenderingContext.POINTS);\n gl.enable(WebGL2RenderingContext.RASTERIZER_DISCARD);\n gl.drawArraysInstanced(\n WebGL2RenderingContext.POINTS,\n first,\n count,\n instanceCount,\n );\n gl.disable(WebGL2RenderingContext.RASTERIZER_DISCARD);\n gl.endTransformFeedback();\n gl.bindBufferBase(WebGL2RenderingContext.TRANSFORM_FEEDBACK_BUFFER, 0, null);\n gl.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER, buffer);\n const array = new Uint8Array(totalBytes);\n gl.getBufferSubData(\n WebGL2RenderingContext.ARRAY_BUFFER,\n 0,\n array,\n 0,\n totalBytes,\n );\n gl.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER, null);\n gl.deleteBuffer(buffer);\n let offset = 0;\n const floatView = new Float32Array(array.buffer);\n for (let instance = 0; instance < instanceCount; ++instance) {\n for (let vertex = 0; vertex < count; ++vertex) {\n let msg = `i=${instance} v=${vertex}:`;\n for (const debugOutput of vertexDebugOutputs) {\n msg += ` ${debugOutput.name}=`;\n switch (debugOutput.typeName) {\n case \"float\":\n msg += `${floatView[offset++]}`;\n break;\n case \"vec2\":\n msg += `${floatView[offset++]},${floatView[offset++]}`;\n break;\n case \"vec3\":\n msg += `${floatView[offset++]},${floatView[offset++]},${\n floatView[offset++]\n }`;\n break;\n case \"vec4\":\n msg += `${floatView[offset++]},${floatView[offset++]},${\n floatView[offset++]\n },${floatView[offset++]}`;\n break;\n }\n }\n console.log(msg);\n }\n }\n}\n\nexport type ShaderCodePart =\n | string\n | ShaderCodePartArray\n | ShaderCodePartFunction;\ninterface ShaderCodePartFunction {\n (): ShaderCodePart;\n}\ntype ShaderCodePartArray = Array;\n\nexport class ShaderCode {\n code = \"\";\n parts = new Set();\n\n add(x: ShaderCodePart) {\n if (this.parts.has(x)) {\n return;\n }\n this.parts.add(x);\n switch (typeof x) {\n case \"string\":\n this.code += x;\n break;\n case \"function\":\n this.add((x)());\n break;\n default:\n if (Array.isArray(x)) {\n for (const y of x) {\n this.add(y);\n }\n } else {\n console.log(\"Invalid code type\", x);\n throw new Error(\"Invalid code type\");\n }\n }\n }\n\n toString(): string {\n return this.code;\n }\n}\n\nexport type ShaderInitializer = (x: ShaderProgram) => void;\nexport type ShaderModule = (x: ShaderBuilder) => void;\n\nexport type ShaderSamplerPrefix = \"i\" | \"u\" | \"\";\n\nexport type ShaderSamplerType =\n | \"sampler2D\"\n | \"usampler2D\"\n | \"isampler2D\"\n | \"sampler3D\"\n | \"usampler3D\"\n | \"isampler3D\";\n\nexport type ShaderInterpolationMode =\n | \"\"\n | \"centroid\"\n | \"flat centroid\"\n | \"smooth centroid\"\n | \"flat\"\n | \"smooth\";\n\nexport const textureTargetForSamplerType = {\n sampler2D: WebGL2RenderingContext.TEXTURE_2D,\n isampler2D: WebGL2RenderingContext.TEXTURE_2D,\n usampler2D: WebGL2RenderingContext.TEXTURE_2D,\n sampler3D: WebGL2RenderingContext.TEXTURE_3D,\n isampler3D: WebGL2RenderingContext.TEXTURE_3D,\n usampler3D: WebGL2RenderingContext.TEXTURE_3D,\n};\n\nexport type DebugOutputType = \"float\" | \"vec2\" | \"vec3\" | \"vec4\";\n\nconst DEBUG_OUTPUT_TYPE_TO_BYTES: Record = {\n float: 4,\n vec2: 8,\n vec3: 12,\n vec4: 16,\n};\n\ninterface VertexDebugOutput {\n typeName: DebugOutputType;\n name: string;\n}\n\nexport class ShaderBuilder {\n private nextSymbolID = 0;\n private nextTextureUnit = 0;\n private uniformsCode = \"\";\n private attributesCode = \"\";\n private varyingsCodeVS = \"\";\n private varyingsCodeFS = \"\";\n private fragmentExtensionsSet = new Set();\n private fragmentExtensions = \"\";\n private vertexCode = new ShaderCode();\n private vertexMain = \"\";\n private fragmentCode = new ShaderCode();\n private outputBufferCode = \"\";\n private fragmentMain = \"\";\n private required = new Set();\n private uniforms = new Array();\n private attributes = new Array();\n private initializers: Array = [];\n private textureUnits = new Map();\n private vertexDebugOutputs: VertexDebugOutput[] = [];\n constructor(public gl: GL) {}\n\n addVertexPositionDebugOutput() {\n this.vertexDebugOutputs.push({ typeName: \"vec4\", name: \"gl_Position\" });\n }\n\n addVertexDebugOutput(typeName: DebugOutputType, name: string) {\n this.addVarying(typeName, name);\n this.vertexDebugOutputs.push({ typeName, name });\n }\n\n allocateTextureUnit(symbol: symbol | string, count = 1) {\n if (this.textureUnits.has(symbol)) {\n throw new Error(\"Duplicate texture unit symbol: \" + symbol.toString());\n }\n const old = this.nextTextureUnit;\n this.nextTextureUnit += count;\n this.textureUnits.set(symbol, old);\n return old;\n }\n\n addTextureSampler(\n samplerType: ShaderSamplerType,\n name: string,\n symbol: symbol | string,\n extent?: number,\n ) {\n const textureUnit = this.allocateTextureUnit(symbol, extent);\n this.addUniform(`highp ${samplerType}`, name, extent);\n this.addInitializer((shader) => {\n if (extent) {\n const textureUnits = new Int32Array(extent);\n for (let i = 0; i < extent; ++i) {\n textureUnits[i] = i + textureUnit;\n }\n shader.gl.uniform1iv(shader.uniform(name), textureUnits);\n } else {\n shader.gl.uniform1i(shader.uniform(name), textureUnit);\n }\n });\n return textureUnit;\n }\n\n symbol(name: string) {\n return name + this.nextSymbolID++;\n }\n\n addAttribute(typeName: string, name: string, location?: number) {\n this.attributes.push(name);\n if (location !== undefined)\n this.attributesCode += `layout(location = ${location})`;\n this.attributesCode += `in ${typeName} ${name};\\n`;\n return name;\n }\n\n addVarying(\n typeName: string,\n name: string,\n interpolationMode: ShaderInterpolationMode = \"\",\n ) {\n this.varyingsCodeVS += `${interpolationMode} out ${typeName} ${name};\\n`;\n this.varyingsCodeFS += `${interpolationMode} in ${typeName} ${name};\\n`;\n }\n\n addOutputBuffer(typeName: string, name: string, location: number | null) {\n if (location !== null) {\n this.outputBufferCode += `layout(location = ${location}) `;\n }\n this.outputBufferCode += `out ${typeName} ${name};\\n`;\n }\n\n addUniform(typeName: string, name: string, extent?: number) {\n this.uniforms.push(name);\n if (extent != null) {\n this.uniformsCode += `uniform ${typeName} ${name}[${extent}];\\n`;\n } else {\n this.uniformsCode += `uniform ${typeName} ${name};\\n`;\n }\n return name;\n }\n\n addFragmentExtension(name: string) {\n if (this.fragmentExtensionsSet.has(name)) {\n return;\n }\n this.fragmentExtensionsSet.add(name);\n this.fragmentExtensions += `#extension ${name} : require\\n`;\n }\n\n addVertexCode(code: ShaderCodePart) {\n this.vertexCode.add(code);\n }\n\n addFragmentCode(code: ShaderCodePart) {\n this.fragmentCode.add(code);\n }\n\n setVertexMain(code: string) {\n this.vertexMain = code;\n }\n addVertexMain(code: string) {\n this.vertexMain = (this.vertexMain || \"\") + code;\n }\n\n setFragmentMain(code: string) {\n this.fragmentMain = `void main() {\n${code}\n}\n`;\n }\n setFragmentMainFunction(code: string) {\n this.fragmentMain = code;\n }\n\n addInitializer(f: ShaderInitializer) {\n this.initializers.push(f);\n }\n\n require(f: ShaderModule): void {\n if (this.required.has(f)) {\n return;\n }\n this.required.add(f);\n f(this);\n }\n\n build() {\n const vertexSource = `#version 300 es\nprecision highp float;\nprecision highp int;\n${this.uniformsCode}\n${this.attributesCode}\n${this.varyingsCodeVS}\nfloat defaultMaxProjectionIntensity = 0.0;\n${this.vertexCode}\nvoid main() {\n${this.vertexMain}\n}\n`;\n const fragmentSource = `#version 300 es\n${this.fragmentExtensions}\nprecision highp float;\nprecision highp int;\n${this.uniformsCode}\n${this.varyingsCodeFS}\n${this.outputBufferCode}\nfloat defaultMaxProjectionIntensity = 0.0;\n${this.fragmentCode}\n${this.fragmentMain}\n`;\n const shader = new ShaderProgram(\n this.gl,\n vertexSource,\n fragmentSource,\n this.uniforms,\n this.attributes,\n this.vertexDebugOutputs,\n );\n shader.textureUnits = this.textureUnits;\n const { initializers } = this;\n if (initializers.length > 0) {\n shader.bind();\n for (const initializer of initializers) {\n initializer(shader);\n }\n }\n return shader;\n }\n}\n\nexport function shaderContainsIdentifiers(\n code: string,\n identifiers: Iterable,\n) {\n const found = new Set();\n for (const identifier of identifiers) {\n const pattern = new RegExp(\n `(?:^|[^a-zA-Z0-9_])${identifier}[^a-zA-Z0-9_])`,\n );\n if (code.match(pattern) !== null) {\n found.add(identifier);\n }\n }\n return found;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport {\n constantWatchableValue,\n WatchableValue,\n TrackableValue,\n} from \"#src/trackable_value.js\";\nimport type { RefCounted } from \"#src/util/disposable.js\";\nimport { stableStringify, verifyString } from \"#src/util/json.js\";\nimport { getObjectId } from \"#src/util/object_id.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type {\n ShaderCompilationError,\n ShaderLinkError,\n ShaderModule,\n ShaderProgram,\n} from \"#src/webgl/shader.js\";\nimport { ShaderBuilder } from \"#src/webgl/shader.js\";\n\n/**\n * undefined means shader has not been compiled. null means shader was compiled successfully.\n */\nexport type WatchableShaderError = WatchableValue<\n ShaderCompilationError | ShaderLinkError | undefined | null\n>;\n\nexport function makeWatchableShaderError() {\n return new WatchableValue<\n ShaderCompilationError | ShaderLinkError | undefined | null\n >(undefined);\n}\n\nexport type TrackableFragmentMain = TrackableValue;\n\nexport function makeTrackableFragmentMain(value: string) {\n return new TrackableValue(value, verifyString);\n}\n\nexport interface ParameterizedShaderGetterResult<\n Parameters = any,\n ExtraParameters = any,\n> {\n shader: ShaderProgram | null;\n fallback: boolean;\n parameters: Parameters;\n extraParameters: ExtraParameters;\n}\n\nexport interface ParameterizedContextDependentShaderGetter<\n Context,\n Parameters,\n ExtraParameters = undefined,\n> {\n (\n context: Context,\n ): ParameterizedShaderGetterResult;\n}\n\nexport interface ParameterizedShaderOptions<\n Parameters = any,\n ExtraParameters = any,\n> {\n memoizeKey: any;\n parameters: WatchableValueInterface;\n fallbackParameters?: WatchableValueInterface | undefined;\n shaderError?: WatchableShaderError | undefined;\n encodeParameters?: (p: Parameters) => any;\n extraParameters?: WatchableValueInterface;\n encodeExtraParameters?: (p: ExtraParameters) => any;\n}\n\nexport function parameterizedContextDependentShaderGetter<\n Context,\n ContextKey,\n Parameters,\n ExtraParameters = undefined,\n>(\n refCounted: RefCounted,\n gl: GL,\n options: ParameterizedShaderOptions & {\n getContextKey: (context: Context) => ContextKey;\n defineShader: (\n builder: ShaderBuilder,\n context: Context,\n parameters: Parameters,\n extraParameters: ExtraParameters,\n ) => void;\n encodeContext?: (context: Context) => any;\n },\n): ParameterizedContextDependentShaderGetter<\n Context,\n Parameters,\n ExtraParameters\n> {\n const shaders = new Map<\n ContextKey,\n ParameterizedShaderGetterResult & {\n parametersGeneration: number;\n extraParametersGeneration: number;\n }\n >();\n const {\n parameters,\n fallbackParameters,\n shaderError,\n encodeParameters = (p: Parameters) => p,\n extraParameters = constantWatchableValue(\n undefined as any as ExtraParameters,\n ),\n encodeExtraParameters = (p: ExtraParameters) => p,\n getContextKey,\n defineShader,\n } = options;\n if (shaderError !== undefined) {\n shaderError.value = undefined;\n }\n const { encodeContext = getContextKey } = options;\n const stringMemoizeKey = stableStringify(options.memoizeKey);\n function getNewShader(\n context: Context,\n parameters: Parameters,\n extraParameters: ExtraParameters,\n ) {\n const key = JSON.stringify({\n id: stringMemoizeKey,\n context: encodeContext(context),\n parameters: encodeParameters(parameters),\n extraParameters: encodeExtraParameters(extraParameters),\n });\n return gl.memoize.get(key, () => {\n const builder = new ShaderBuilder(gl);\n defineShader(builder, context, parameters, extraParameters);\n return builder.build();\n });\n }\n function getter(context: Context) {\n const contextKey = getContextKey(context);\n let entry = shaders.get(contextKey);\n if (entry === undefined) {\n entry = {\n parametersGeneration: -1,\n extraParametersGeneration: -1,\n shader: null,\n fallback: false,\n parameters: parameters.value,\n extraParameters: extraParameters.value,\n };\n shaders.set(contextKey, entry);\n }\n const parametersGeneration = parameters.changed.count;\n const extraParametersGeneration = extraParameters.changed.count;\n if (\n parametersGeneration === entry.parametersGeneration &&\n extraParametersGeneration === entry.extraParametersGeneration\n ) {\n return entry;\n }\n const parametersValue = (entry.parameters = parameters.value);\n const extraParametersValue = (entry.extraParameters =\n extraParameters.value);\n const oldShader = entry.shader;\n entry.parametersGeneration = parametersGeneration;\n entry.extraParametersGeneration = extraParametersGeneration;\n let newShader: ShaderProgram | null = null;\n try {\n newShader = getNewShader(context, parametersValue, extraParametersValue);\n entry.fallback = false;\n if (fallbackParameters !== undefined) {\n fallbackParameters.value = parametersValue;\n }\n if (shaderError !== undefined) {\n shaderError.value = null;\n }\n } catch (e) {\n if (shaderError !== undefined) {\n shaderError.value = e;\n }\n if (fallbackParameters !== undefined) {\n try {\n const fallbackParametersValue = fallbackParameters.value;\n newShader = getNewShader(\n context,\n fallbackParametersValue,\n extraParametersValue,\n );\n entry.parameters = fallbackParametersValue;\n entry.fallback = true;\n } catch {\n // Ignore error creating fallback shader.\n }\n }\n }\n if (oldShader !== null) {\n oldShader.dispose();\n }\n entry.shader = newShader;\n return entry;\n }\n refCounted.registerDisposer(() => {\n for (const entry of shaders.values()) {\n const { shader } = entry;\n if (shader !== null) {\n shader.dispose();\n }\n }\n });\n return getter;\n}\n\nexport interface ParameterizedEmitterDependentShaderOptions<\n Parameters = any,\n ExtraParameters = any,\n> extends ParameterizedShaderOptions {\n defineShader: (\n builder: ShaderBuilder,\n parameters: Parameters,\n extraParameters: ExtraParameters,\n ) => void;\n}\n\nexport type ParameterizedEmitterDependentShaderGetter<\n Parameters = any,\n ExtraParameters = any,\n> = ParameterizedContextDependentShaderGetter<\n ShaderModule,\n Parameters,\n ExtraParameters\n>;\n\nexport function parameterizedEmitterDependentShaderGetter<\n Parameters,\n ExtraParameters = undefined,\n>(\n refCounted: RefCounted,\n gl: GL,\n options: ParameterizedEmitterDependentShaderOptions<\n Parameters,\n ExtraParameters\n >,\n): ParameterizedEmitterDependentShaderGetter {\n return parameterizedContextDependentShaderGetter(refCounted, gl, {\n ...options,\n getContextKey: (emitter: ShaderModule) => emitter,\n encodeContext: (emitter: ShaderModule) => getObjectId(emitter),\n defineShader: (\n builder,\n emitter: ShaderModule,\n parameters,\n extraParameters,\n ) => {\n builder.require(emitter);\n return options.defineShader(builder, parameters, extraParameters);\n },\n });\n}\n\nexport function shaderCodeWithLineDirective(\n code: string,\n sourceStringNumber = 1,\n line = 0,\n) {\n return `\\n#line ${line} ${sourceStringNumber}\\n` + code;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { Disposable } from \"#src/util/disposable.js\";\nimport { RefCountedValue } from \"#src/util/disposable.js\";\nimport { stableStringify } from \"#src/util/json.js\";\nimport { getObjectId } from \"#src/util/object_id.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { AttributeIndex } from \"#src/webgl/shader.js\";\n\nexport type BufferType = number;\nexport type WebGLDataType = number;\nexport type WebGLBufferUsage = number;\nexport class Buffer implements Disposable {\n buffer: WebGLBuffer | null;\n constructor(\n public gl: WebGL2RenderingContext,\n public bufferType: BufferType = WebGL2RenderingContext.ARRAY_BUFFER,\n ) {\n this.gl = gl;\n // This should never return null.\n this.buffer = gl.createBuffer();\n }\n\n bind() {\n this.gl.bindBuffer(this.bufferType, this.buffer);\n }\n\n bindToVertexAttrib(\n location: AttributeIndex,\n componentsPerVertexAttribute: number,\n attributeType: WebGLDataType = WebGL2RenderingContext.FLOAT,\n normalized = false,\n stride = 0,\n offset = 0,\n ) {\n this.bind();\n this.gl.enableVertexAttribArray(location);\n this.gl.vertexAttribPointer(\n location,\n componentsPerVertexAttribute,\n attributeType,\n normalized,\n stride,\n offset,\n );\n }\n\n bindToVertexAttribI(\n location: AttributeIndex,\n componentsPerVertexAttribute: number,\n attributeType: WebGLDataType = WebGL2RenderingContext.UNSIGNED_INT,\n stride = 0,\n offset = 0,\n ) {\n this.bind();\n this.gl.enableVertexAttribArray(location);\n this.gl.vertexAttribIPointer(\n location,\n componentsPerVertexAttribute,\n attributeType,\n stride,\n offset,\n );\n }\n\n setData(\n data: ArrayBufferView,\n usage: WebGLBufferUsage = WebGL2RenderingContext.STATIC_DRAW,\n ) {\n const gl = this.gl;\n this.bind();\n gl.bufferData(this.bufferType, data, usage);\n }\n\n dispose() {\n this.gl.deleteBuffer(this.buffer);\n this.buffer = undefined;\n this.gl = undefined;\n }\n\n static fromData(\n gl: WebGL2RenderingContext,\n data: ArrayBufferView,\n bufferType?: BufferType,\n usage?: WebGLBufferUsage,\n ) {\n const buffer = new Buffer(gl, bufferType);\n buffer.setData(data, usage);\n return buffer;\n }\n}\n\nexport function getMemoizedBuffer(\n gl: GL,\n bufferType: number,\n getter: (...args: any[]) => ArrayBufferView,\n ...args: any[]\n) {\n return gl.memoize.get(\n stableStringify({\n id: \"getMemoizedBuffer\",\n getter: getObjectId(getter),\n args,\n }),\n () => {\n const result = new RefCountedValue(\n Buffer.fromData(\n gl,\n getter(...args),\n bufferType,\n WebGL2RenderingContext.STATIC_DRAW,\n ),\n );\n result.registerDisposer(result.value);\n return result;\n },\n );\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { tile2dArray } from \"#src/util/array.js\";\nimport { getMemoizedBuffer } from \"#src/webgl/buffer.js\";\nimport type { GL } from \"#src/webgl/context.js\";\n\nexport function getSquareCornersArray(\n startX = -1,\n startY = -1,\n endX = 1,\n endY = 1,\n minorTiles = 1,\n majorTiles = 1,\n) {\n return tile2dArray(\n new Float32Array([\n startX,\n startY, //\n startX,\n endY, //\n endX,\n endY, //\n endX,\n startY, //\n ]),\n /*majorDimension=*/ 2,\n minorTiles,\n majorTiles,\n );\n}\n\nexport function getCubeCornersArray(\n startX = -1,\n startY = -1,\n startZ = -1,\n endX = 1,\n endY = 1,\n endZ = 1,\n minorTiles = 1,\n majorTiles = 1,\n) {\n return tile2dArray(\n new Float32Array([\n startX,\n startY,\n startZ, //\n endX,\n startY,\n startZ, //\n startX,\n endY,\n startZ, //\n endX,\n endY,\n startZ, //\n startX,\n startY,\n endZ, //\n endX,\n startY,\n endZ, //\n startX,\n endY,\n endZ, //\n endX,\n endY,\n endZ, //\n ]),\n /*majorDimension=*/ 3,\n minorTiles,\n majorTiles,\n );\n}\n\nexport function getSquareCornersBuffer(\n gl: GL,\n startX = -1,\n startY = -1,\n endX = 1,\n endY = 1,\n minorTiles = 1,\n majorTiles = 1,\n) {\n return getMemoizedBuffer(\n gl,\n WebGL2RenderingContext.ARRAY_BUFFER,\n getSquareCornersArray,\n startX,\n startY,\n endX,\n endY,\n minorTiles,\n majorTiles,\n ).value;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { GL } from \"#src/webgl/context.js\";\n\n/**\n * Sets parameters to make a texture suitable for use as a raw array: NEAREST\n * filtering, clamping.\n */\nexport function setRawTextureParameters(gl: WebGL2RenderingContext) {\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_2D,\n WebGL2RenderingContext.TEXTURE_MIN_FILTER,\n WebGL2RenderingContext.NEAREST,\n );\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_2D,\n WebGL2RenderingContext.TEXTURE_MAG_FILTER,\n WebGL2RenderingContext.NEAREST,\n );\n // Prevents s-coordinate wrapping (repeating). Repeating not\n // permitted for non-power-of-2 textures.\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_2D,\n WebGL2RenderingContext.TEXTURE_WRAP_S,\n WebGL2RenderingContext.CLAMP_TO_EDGE,\n );\n // Prevents t-coordinate wrapping (repeating). Repeating not\n // permitted for non-power-of-2 textures.\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_2D,\n WebGL2RenderingContext.TEXTURE_WRAP_T,\n WebGL2RenderingContext.CLAMP_TO_EDGE,\n );\n}\n\nexport function setRawTexture3DParameters(gl: WebGL2RenderingContext) {\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_3D,\n WebGL2RenderingContext.TEXTURE_MIN_FILTER,\n WebGL2RenderingContext.NEAREST,\n );\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_3D,\n WebGL2RenderingContext.TEXTURE_MAG_FILTER,\n WebGL2RenderingContext.NEAREST,\n );\n // Prevents s-coordinate wrapping (repeating). Repeating not\n // permitted for non-power-of-2 textures.\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_3D,\n WebGL2RenderingContext.TEXTURE_WRAP_S,\n WebGL2RenderingContext.CLAMP_TO_EDGE,\n );\n // Prevents t-coordinate wrapping (repeating). Repeating not\n // permitted for non-power-of-2 textures.\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_3D,\n WebGL2RenderingContext.TEXTURE_WRAP_T,\n WebGL2RenderingContext.CLAMP_TO_EDGE,\n );\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_3D,\n WebGL2RenderingContext.TEXTURE_WRAP_R,\n WebGL2RenderingContext.CLAMP_TO_EDGE,\n );\n}\n\nexport function resizeTexture(\n gl: GL,\n texture: WebGLTexture | null,\n width: number,\n height: number,\n internalFormat: number = WebGL2RenderingContext.RGBA8,\n format: number = WebGL2RenderingContext.RGBA,\n dataType: number = WebGL2RenderingContext.UNSIGNED_BYTE,\n) {\n gl.activeTexture(WebGL2RenderingContext.TEXTURE0 + gl.tempTextureUnit);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, texture);\n setRawTextureParameters(gl);\n gl.texImage2D(\n WebGL2RenderingContext.TEXTURE_2D,\n 0,\n /*internalformat=*/ internalFormat,\n /*width=*/ width,\n /*height=*/ height,\n /*border=*/ 0,\n /*format=*/ format,\n dataType,\n null,\n );\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, null);\n}\n\nexport function setTextureFromCanvas(\n gl: GL,\n texture: WebGLTexture | null,\n canvas: HTMLCanvasElement,\n) {\n gl.activeTexture(WebGL2RenderingContext.TEXTURE0 + gl.tempTextureUnit);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, texture);\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_2D,\n WebGL2RenderingContext.TEXTURE_MIN_FILTER,\n WebGL2RenderingContext.LINEAR,\n );\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_2D,\n WebGL2RenderingContext.TEXTURE_MAG_FILTER,\n WebGL2RenderingContext.LINEAR,\n );\n // Prevents s-coordinate wrapping (repeating). Repeating not permitted for non-power-of-2\n // textures.\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_2D,\n WebGL2RenderingContext.TEXTURE_WRAP_S,\n WebGL2RenderingContext.CLAMP_TO_EDGE,\n );\n // Prevents t-coordinate wrapping (repeating). Repeating not permitted for non-power-of-2\n // textures.\n gl.texParameteri(\n WebGL2RenderingContext.TEXTURE_2D,\n WebGL2RenderingContext.TEXTURE_WRAP_T,\n WebGL2RenderingContext.CLAMP_TO_EDGE,\n );\n gl.pixelStorei(WebGL2RenderingContext.UNPACK_FLIP_Y_WEBGL, 1);\n gl.pixelStorei(WebGL2RenderingContext.UNPACK_ALIGNMENT, 4);\n gl.texImage2D(\n WebGL2RenderingContext.TEXTURE_2D,\n /*level=*/ 0,\n /*internalformat=*/ WebGL2RenderingContext.RGBA8,\n /*format=*/ WebGL2RenderingContext.RGBA,\n WebGL2RenderingContext.UNSIGNED_BYTE,\n canvas,\n );\n gl.pixelStorei(WebGL2RenderingContext.UNPACK_FLIP_Y_WEBGL, 0);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, null);\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getObjectId } from \"#src/util/object_id.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { ShaderModule, ShaderProgram } from \"#src/webgl/shader.js\";\nimport { ShaderBuilder } from \"#src/webgl/shader.js\";\n\nexport function defineCopyFragmentShader(builder: ShaderBuilder) {\n builder.addOutputBuffer(\"vec4\", \"v4f_fragColor\", null);\n builder.setFragmentMain(\"v4f_fragColor = getValue0();\");\n}\n\nexport function elementWiseTextureShader(\n gl: GL,\n shaderModule: ShaderModule = defineCopyFragmentShader,\n numTextures = 1,\n): ShaderProgram {\n return gl.memoize.get(\n `elementWiseTextureShader:${numTextures}:${getObjectId(shaderModule)}`,\n () => {\n const builder = new ShaderBuilder(gl);\n builder.addVarying(\"vec2\", \"vTexCoord\");\n builder.addUniform(\"sampler2D\", \"uSampler\", numTextures);\n builder.addInitializer((shader) => {\n const textureIndices: number[] = [];\n for (let i = 0; i < numTextures; ++i) {\n textureIndices[i] = i;\n }\n gl.uniform1iv(shader.uniform(\"uSampler\"), textureIndices);\n });\n for (let i = 0; i < numTextures; ++i) {\n builder.addFragmentCode(`\nvec4 getValue${i}() {\n return texture(uSampler[${i}], vTexCoord);\n}\n`);\n }\n builder.addUniform(\"mat4\", \"uProjectionMatrix\");\n builder.require(shaderModule);\n builder.addAttribute(\"vec4\", \"aVertexPosition\");\n builder.addAttribute(\"vec2\", \"aTexCoord\");\n builder.setVertexMain(\n \"vTexCoord = aTexCoord; gl_Position = uProjectionMatrix * aVertexPosition;\",\n );\n return builder.build();\n },\n );\n}\n\nexport function trivialTextureShader(gl: GL): ShaderProgram {\n return elementWiseTextureShader(gl, defineCopyFragmentShader, 1);\n}\n\nexport function trivialColorShader(gl: GL): ShaderProgram {\n return gl.memoize.get(\"trivialColorShader\", () => {\n const builder = new ShaderBuilder(gl);\n builder.addVarying(\"vec4\", \"vColor\");\n builder.addOutputBuffer(\"vec4\", \"v4f_fragColor\", null);\n builder.setFragmentMain(\"v4f_fragColor = vColor;\");\n builder.addAttribute(\"vec4\", \"aVertexPosition\");\n builder.addAttribute(\"vec4\", \"aColor\");\n builder.addUniform(\"mat4\", \"uProjectionMatrix\");\n builder.setVertexMain(\n \"vColor = aColor; gl_Position = uProjectionMatrix * aVertexPosition;\",\n );\n return builder.build();\n });\n}\n\nexport function trivialUniformColorShader(gl: GL): ShaderProgram {\n return gl.memoize.get(\"trivialUniformColorShader\", () => {\n const builder = new ShaderBuilder(gl);\n builder.addUniform(\"mat4\", \"uProjectionMatrix\");\n builder.addAttribute(\"vec4\", \"aVertexPosition\");\n builder.addUniform(\"vec4\", \"uColor\");\n builder.addOutputBuffer(\"vec4\", \"v4f_fragColor\", null);\n builder.setFragmentMain(\"v4f_fragColor = uColor;\");\n builder.setVertexMain(\"gl_Position = uProjectionMatrix * aVertexPosition;\");\n return builder.build();\n });\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { identityMat4 } from \"#src/util/geom.js\";\nimport { getObjectId } from \"#src/util/object_id.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { ShaderModule, ShaderProgram } from \"#src/webgl/shader.js\";\nimport { getSquareCornersBuffer } from \"#src/webgl/square_corners_buffer.js\";\nimport { resizeTexture } from \"#src/webgl/texture.js\";\nimport {\n defineCopyFragmentShader,\n elementWiseTextureShader,\n} from \"#src/webgl/trivial_shaders.js\";\n\nexport abstract class SizeManaged extends RefCounted {\n width = Number.NaN;\n height = Number.NaN;\n\n hasSize(width: number, height: number) {\n return this.width === width && this.height === height;\n }\n\n resize(width: number, height: number) {\n if (this.hasSize(width, height)) {\n return;\n }\n this.width = width;\n this.height = height;\n\n this.performResize();\n }\n protected abstract performResize(): void;\n}\n\nexport class Renderbuffer extends SizeManaged {\n renderbuffer: WebGLRenderbuffer | null = null;\n\n constructor(\n public gl: GL,\n public internalformat: number,\n ) {\n super();\n this.renderbuffer = gl.createRenderbuffer();\n }\n\n protected performResize() {\n const { gl } = this;\n gl.bindRenderbuffer(gl.RENDERBUFFER, this.renderbuffer);\n gl.renderbufferStorage(\n gl.RENDERBUFFER,\n this.internalformat,\n this.width,\n this.height,\n );\n gl.bindRenderbuffer(gl.RENDERBUFFER, null);\n }\n\n disposed() {\n this.gl.deleteRenderbuffer(this.renderbuffer);\n }\n\n attachToFramebuffer(attachment: number) {\n const { gl } = this;\n gl.framebufferRenderbuffer(\n gl.FRAMEBUFFER,\n attachment,\n gl.RENDERBUFFER,\n this.renderbuffer,\n );\n }\n}\n\nexport class DepthRenderbuffer extends Renderbuffer {\n constructor(\n public gl: GL,\n public includeStencilBuffer = false,\n ) {\n super(gl, includeStencilBuffer ? gl.DEPTH_STENCIL : gl.DEPTH_COMPONENT16);\n }\n attachToFramebuffer() {\n const { gl } = this;\n super.attachToFramebuffer(\n this.includeStencilBuffer\n ? gl.DEPTH_STENCIL_ATTACHMENT\n : gl.DEPTH_ATTACHMENT,\n );\n }\n}\n\nexport class DepthStencilRenderbuffer extends DepthRenderbuffer {\n constructor(gl: GL) {\n super(gl, /*includeStencilBuffer=*/ true);\n }\n}\n\nexport const StencilRenderbuffer = DepthStencilRenderbuffer;\n\nexport class Framebuffer extends RefCounted {\n framebuffer = this.gl.createFramebuffer();\n constructor(public gl: GL) {\n super();\n }\n disposed() {\n const { gl } = this;\n gl.deleteFramebuffer(this.framebuffer);\n }\n bind() {\n const { gl } = this;\n gl.bindFramebuffer(gl.FRAMEBUFFER, this.framebuffer);\n }\n unbind() {\n const { gl } = this;\n gl.bindFramebuffer(gl.FRAMEBUFFER, null);\n }\n}\n\nexport class TextureBuffer extends SizeManaged {\n texture: WebGLTexture | null;\n\n constructor(\n public gl: GL,\n public internalFormat: number,\n public format: number,\n public dataType: number,\n ) {\n super();\n this.texture = gl.createTexture();\n }\n\n protected performResize() {\n resizeTexture(\n this.gl,\n this.texture,\n this.width,\n this.height,\n this.internalFormat,\n this.format,\n this.dataType,\n );\n }\n\n disposed() {\n this.gl.deleteTexture(this.texture);\n }\n\n attachToFramebuffer(attachment: number) {\n const { gl } = this;\n gl.framebufferTexture2D(\n gl.FRAMEBUFFER,\n attachment,\n gl.TEXTURE_2D,\n this.texture,\n /*level=*/ 0,\n );\n }\n}\n\nexport class DepthTextureBuffer extends TextureBuffer {\n // biome-ignore lint/complexity/noUselessConstructor: adds defaults\n constructor(\n gl: GL,\n internalFormat: number = WebGL2RenderingContext.DEPTH_COMPONENT16,\n format: number = WebGL2RenderingContext.DEPTH_COMPONENT,\n dataType: number = WebGL2RenderingContext.UNSIGNED_SHORT,\n ) {\n super(gl, internalFormat, format, dataType);\n }\n\n attachToFramebuffer() {\n super.attachToFramebuffer(\n this.format === WebGL2RenderingContext.DEPTH_COMPONENT\n ? WebGL2RenderingContext.DEPTH_ATTACHMENT\n : WebGL2RenderingContext.DEPTH_STENCIL_ATTACHMENT,\n );\n }\n}\n\nexport function makeTextureBuffers(\n gl: GL,\n count: number,\n internalFormat: number = WebGL2RenderingContext.RGBA8,\n format: number = WebGL2RenderingContext.RGBA,\n dataType: number = WebGL2RenderingContext.UNSIGNED_BYTE,\n) {\n const result = new Array();\n for (let i = 0; i < count; ++i) {\n result[i] = new TextureBuffer(gl, internalFormat, format, dataType);\n }\n return result;\n}\n\nexport class FramebufferConfiguration<\n ColorBuffer extends TextureBuffer | Renderbuffer =\n | TextureBuffer\n | Renderbuffer,\n DepthBuffer extends DepthTextureBuffer | DepthRenderbuffer =\n | DepthTextureBuffer\n | DepthRenderbuffer,\n> extends RefCounted {\n width = Number.NaN;\n height = Number.NaN;\n\n colorBuffers: ColorBuffer[];\n framebuffer: Framebuffer;\n depthBuffer: DepthBuffer | undefined;\n fullAttachmentList = new Array();\n private attachmentVerified = false;\n singleAttachmentList = [this.gl.COLOR_ATTACHMENT0];\n\n constructor(\n public gl: GL,\n configuration: {\n framebuffer?: Framebuffer;\n colorBuffers: ColorBuffer[];\n depthBuffer?: DepthBuffer;\n },\n ) {\n super();\n const {\n framebuffer = new Framebuffer(gl),\n colorBuffers,\n depthBuffer,\n } = configuration;\n this.framebuffer = this.registerDisposer(framebuffer);\n this.colorBuffers = colorBuffers;\n this.depthBuffer = depthBuffer;\n if (depthBuffer !== undefined) {\n this.registerDisposer(depthBuffer);\n }\n const { fullAttachmentList } = this;\n colorBuffers.forEach((buffer, i) => {\n this.registerDisposer(buffer);\n fullAttachmentList[i] = gl.COLOR_ATTACHMENT0 + i;\n });\n }\n\n hasSize(width: number, height: number) {\n return this.width === width && this.height === height;\n }\n\n bind(width: number, height: number) {\n this.width = width;\n this.height = height;\n this.framebuffer.bind();\n const { gl, depthBuffer } = this;\n if (depthBuffer !== undefined) {\n depthBuffer.resize(width, height);\n depthBuffer.attachToFramebuffer();\n } else {\n gl.framebufferRenderbuffer(\n WebGL2RenderingContext.FRAMEBUFFER,\n WebGL2RenderingContext.DEPTH_STENCIL_ATTACHMENT,\n WebGL2RenderingContext.RENDERBUFFER,\n null,\n );\n }\n this.colorBuffers.forEach((buffer, i) => {\n buffer.resize(width, height);\n buffer.attachToFramebuffer(gl.COLOR_ATTACHMENT0 + i);\n });\n gl.drawBuffers(this.fullAttachmentList);\n this.verifyAttachment();\n gl.viewport(0, 0, width, height);\n }\n\n bindSingle(textureIndex: number) {\n const { gl } = this;\n this.framebuffer.bind();\n\n // If this texture is still be bound to color attachment textureIndex, the attachment will fail\n // (at least on some browsers). Therefore, if textureIndex is not 0, we clear the attachment.\n // In the case that textureIndex is 0, the attachment will be overridden anyway.\n if (textureIndex !== 0) {\n gl.framebufferTexture2D(\n gl.FRAMEBUFFER,\n gl.COLOR_ATTACHMENT0 + textureIndex,\n gl.TEXTURE_2D,\n null,\n /*level=*/ 0,\n );\n }\n\n gl.bindTexture(gl.TEXTURE_2D, null);\n this.colorBuffers[textureIndex].attachToFramebuffer(gl.COLOR_ATTACHMENT0);\n gl.drawBuffers(this.singleAttachmentList);\n }\n\n unbind() {\n this.framebuffer.unbind();\n }\n\n readPixelFloat32IntoBuffer(\n textureIndex: number,\n glWindowX: number,\n glWindowY: number,\n offset: number,\n width = 1,\n height = 1,\n ) {\n const { gl } = this;\n try {\n this.bindSingle(textureIndex);\n // Reading just the red channel using a format of RED fails with certain WebGL\n // implementations. Using RGBA seems to have better compatibility.\n gl.readPixels(\n glWindowX,\n glWindowY,\n width,\n height,\n WebGL2RenderingContext.RGBA,\n WebGL2RenderingContext.FLOAT,\n offset,\n );\n } finally {\n this.framebuffer.unbind();\n }\n }\n\n verifyAttachment() {\n if (this.attachmentVerified) {\n return;\n }\n const { gl } = this;\n const framebufferStatus = gl.checkFramebufferStatus(gl.FRAMEBUFFER);\n if (framebufferStatus !== gl.FRAMEBUFFER_COMPLETE) {\n throw new Error(\n `Framebuffer configuration not supported: ${framebufferStatus}`,\n );\n }\n this.attachmentVerified = true;\n }\n}\n\nexport class OffscreenCopyHelper extends RefCounted {\n constructor(\n public gl: GL,\n public shader: ShaderProgram,\n ) {\n super();\n this.registerDisposer(shader);\n }\n private copyVertexPositionsBuffer = getSquareCornersBuffer(this.gl);\n private copyTexCoordsBuffer = getSquareCornersBuffer(this.gl, 0, 0, 1, 1);\n\n draw(...textures: (WebGLTexture | null)[]) {\n const { gl, shader } = this;\n shader.bind();\n\n const numTextures = textures.length;\n for (let i = 0; i < numTextures; ++i) {\n gl.activeTexture(gl.TEXTURE0 + i);\n gl.bindTexture(gl.TEXTURE_2D, textures[i]);\n }\n\n gl.uniformMatrix4fv(\n shader.uniform(\"uProjectionMatrix\"),\n false,\n identityMat4,\n );\n\n const aVertexPosition = shader.attribute(\"aVertexPosition\");\n this.copyVertexPositionsBuffer.bindToVertexAttrib(\n aVertexPosition,\n /*components=*/ 2,\n );\n\n const aTexCoord = shader.attribute(\"aTexCoord\");\n this.copyTexCoordsBuffer.bindToVertexAttrib(aTexCoord, /*components=*/ 2);\n\n gl.drawArrays(gl.TRIANGLE_FAN, 0, 4);\n\n gl.disableVertexAttribArray(aVertexPosition);\n gl.disableVertexAttribArray(aTexCoord);\n\n for (let i = 0; i < numTextures; ++i) {\n gl.activeTexture(gl.TEXTURE0 + i);\n gl.bindTexture(gl.TEXTURE_2D, null);\n }\n }\n\n static get(\n gl: GL,\n shaderModule: ShaderModule = defineCopyFragmentShader,\n numTextures = 1,\n ) {\n return gl.memoize.get(\n `OffscreenCopyHelper:${numTextures}:${getObjectId(shaderModule)}`,\n () =>\n new OffscreenCopyHelper(\n gl,\n elementWiseTextureShader(gl, shaderModule, numTextures),\n ),\n );\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n DATA_TYPE_BYTES,\n DATA_TYPE_SIGNED,\n DataType,\n} from \"#src/util/data_type.js\";\nimport type {\n AttributeIndex,\n ShaderBuilder,\n ShaderCodePart,\n} from \"#src/webgl/shader.js\";\n\nexport const glsl_mixLinear = `\nfloat mixLinear(float x, float y, float a) { return mix(x, y, a); }\n`;\n\n// Hue, saturation, and value are in [0, 1] range.\nexport const glsl_hsvToRgb = `\nvec3 hueToRgb(float hue) {\n float hue6 = hue * 6.0;\n float r = abs(hue6 - 3.0) - 1.0;\n float g = 2.0 - abs(hue6 - 2.0);\n float b = 2.0 - abs(hue6 - 4.0);\n return clamp(vec3(r, g, b), 0.0, 1.0);\n}\nvec3 hsvToRgb(vec3 c) {\n vec3 hueRgb = hueToRgb(c.x);\n return c.z * ((hueRgb - 1.0) * c.y + 1.0);\n}\n`;\n\nexport const glsl_uint64 = `\nstruct uint64_t {\n highp uvec2 value;\n};\nstruct uint64x2_t {\n highp uvec4 value;\n};\nuint64_t mixLinear(uint64_t x, uint64_t y, float a) {\n return x;\n}\nuint64_t toUint64(uint64_t x) { return x; }\n`;\n\nexport const glsl_unpackUint64leFromUint32 = [\n glsl_uint64,\n `\nuint64_t unpackUint64leFromUint32(highp uvec2 x) {\n uint64_t result;\n result.value = x;\n return result;\n}\nuint64x2_t unpackUint64leFromUint32(highp uvec4 x) {\n uint64x2_t result;\n result.value = x;\n return result;\n}\n`,\n];\n\nexport const glsl_equalUint64 = [\n glsl_uint64,\n `\nbool equals(uint64_t a, uint64_t b) {\n return a.value == b.value;\n}\n`,\n];\n\nexport const glsl_compareLessThanUint64 = [\n glsl_uint64,\n `\nbool compareLessThan(uint64_t a, uint64_t b) {\n return (a.value[1] < b.value[1])||\n (a.value[1] == b.value[1] && a.value[0] < b.value[0]);\n}\n`,\n];\n\nexport const glsl_subtractUint64 = [\n glsl_uint64,\n `\nuint64_t subtract(uint64_t a, uint64_t b) {\n if (a.value[0] < b.value[0]) {\n --a.value[1];\n }\n a.value -= b.value;\n return a;\n}\n`,\n];\n\nexport const glsl_addUint64 = [\n glsl_uint64,\n `\nuint64_t add(uint64_t a, uint64_t b) {\n a.value[0] += b.value[0];\n if (a.value[0] < b.value[0]) {\n ++a.value[1];\n }\n a.value[1] += b.value[1];\n return a;\n}\n`,\n];\n\nexport const glsl_addSaturateUint64 = [\n glsl_addUint64,\n glsl_compareLessThanUint64,\n `\nuint64_t addSaturate(uint64_t a, uint64_t b) {\n a = add(a, b);\n if (compareLessThan(a, b)) {\n a.value = uvec2(0xffffffffu, 0xffffffffu);\n }\n return a;\n}\n`,\n];\n\nexport const glsl_subtractSaturateUint64 = [\n glsl_subtractUint64,\n glsl_compareLessThanUint64,\n `\nuint64_t subtractSaturate(uint64_t a, uint64_t b) {\n b = subtract(a, b);\n if (compareLessThan(a, b)) {\n b.value = uvec2(0u, 0u);\n }\n return b;\n}\n`,\n];\n\nexport const glsl_shiftRightUint64 = [\n glsl_uint64,\n `\nuint64_t shiftRight(uint64_t a, int shift) {\n if (shift >= 32) {\n return uint64_t(uvec2(a.value[1] >> (shift - 32), 0u));\n } else if (shift == 0) {\n return a;\n } else {\n return uint64_t(uvec2((a.value[0] >> shift) | (a.value[1] << (32 - shift)), a.value[1] >> shift));\n }\n}\n`,\n];\n\nexport const glsl_shiftLeftUint64 = [\n glsl_uint64,\n `\nuint64_t shiftLeft(uint64_t a, int shift) {\n if (shift >= 32) {\n return uint64_t(uvec2(0u, a.value[0] << (shift - 32)));\n } else if (shift == 0) {\n return a;\n } else {\n return uint64_t(uvec2(a.value[0] << shift, (a.value[1] << shift) | (a.value[0] >> (32 - shift))));\n }\n}\n`,\n];\n\nexport const glsl_uint8 = [\n glsl_uint64,\n `\nstruct uint8_t {\n highp uint value;\n};\nstruct uint8x2_t {\n highp uvec2 value;\n};\nstruct uint8x3_t {\n highp uvec3 value;\n};\nstruct uint8x4_t {\n highp uvec4 value;\n};\nuint8_t mixLinear(uint8_t x, uint8_t y, highp float a) {\n return uint8_t(uint(round(mix(float(x.value), float(y.value), a))));\n}\nhighp uint toRaw(uint8_t x) { return x.value; }\nhighp float toNormalized(uint8_t x) { return float(x.value) / 255.0; }\nhighp uvec2 toRaw(uint8x2_t x) { return x.value; }\nhighp vec2 toNormalized(uint8x2_t x) { return vec2(x.value) / 255.0; }\nhighp uvec3 toRaw(uint8x3_t x) { return x.value; }\nvec3 toNormalized(uint8x3_t x) { return vec3(x.value) / 255.0; }\nhighp uvec4 toRaw(uint8x4_t x) { return x.value; }\nvec4 toNormalized(uint8x4_t x) { return vec4(x.value) / 255.0; }\nuint64_t toUint64(uint8_t x) {\n uint64_t result;\n result.value[0] = x.value;\n result.value[1] = 0u;\n return result;\n}\nuint8_t uint8FromFloat(highp float x) {\n return uint8_t(uint(clamp(x, 0.0, 255.0)));\n}\n`,\n];\n\nexport const glsl_int8 = [\n glsl_uint64,\n `\nstruct int8_t {\n highp int value;\n};\nstruct int8x2_t {\n highp ivec2 value;\n};\nstruct int8x3_t {\n highp ivec3 value;\n};\nstruct int8x4_t {\n highp ivec4 value;\n};\nint8_t mixLinear(int8_t x, int8_t y, highp float a) {\n return int8_t(int(round(mix(float(x.value), float(y.value), a))));\n}\nhighp int toRaw(int8_t x) { return x.value; }\nhighp ivec2 toRaw(int8x2_t x) { return x.value; }\nhighp ivec3 toRaw(int8x3_t x) { return x.value; }\nhighp ivec4 toRaw(int8x4_t x) { return x.value; }\nuint64_t toUint64(int8_t x) {\n uint64_t result;\n result.value[0] = uint(x.value);\n result.value[1] = uint(x.value >> 31);\n return result;\n}\nint8_t int8FromFloat(highp float x) {\n return int8_t(int(clamp(x, -128.0, 127.0)));\n}\n`,\n];\n\nexport const glsl_float = `\nhighp float toRaw(highp float x) { return x; }\nhighp float toNormalized(highp float x) { return x; }\nvec2 toRaw(vec2 x) { return x; }\nvec2 toNormalized(vec2 x) { return x; }\nvec3 toRaw(vec3 x) { return x; }\nvec3 toNormalized(vec3 x) { return x; }\nvec4 toRaw(vec4 x) { return x; }\nvec4 toNormalized(vec4 x) { return x; }\n`;\n\nexport const glsl_uint16 = [\n glsl_uint64,\n `\nstruct uint16_t {\n highp uint value;\n};\nstruct uint16x2_t {\n highp uvec2 value;\n};\nuint16_t mixLinear(uint16_t x, uint16_t y, highp float a) {\n return uint16_t(uint(round(mix(float(x.value), float(y.value), a))));\n}\nhighp uint toRaw(uint16_t x) { return x.value; }\nhighp float toNormalized(uint16_t x) { return float(toRaw(x)) / 65535.0; }\nhighp uvec2 toRaw(uint16x2_t x) { return x.value; }\nhighp vec2 toNormalized(uint16x2_t x) { return vec2(toRaw(x)) / 65535.0; }\nuint64_t toUint64(uint16_t x) {\n uint64_t result;\n result.value[0] = x.value;\n result.value[1] = 0u;\n return result;\n}\nuint16_t uint16FromFloat(highp float x) {\n return uint16_t(uint(clamp(x, 0.0, 65535.0)));\n}\n`,\n];\n\nexport const glsl_int16 = [\n glsl_uint64,\n `\nstruct int16_t {\n highp int value;\n};\nstruct int16x2_t {\n highp ivec2 value;\n};\nint16_t mixLinear(int16_t x, int16_t y, highp float a) {\n return int16_t(int(round(mix(float(x.value), float(y.value), a))));\n}\nhighp int toRaw(int16_t x) { return x.value; }\nhighp ivec2 toRaw(int16x2_t x) { return x.value; }\nuint64_t toUint64(int16_t x) {\n uint64_t result;\n result.value[0] = uint(x.value);\n result.value[1] = uint(x.value >> 31);\n return result;\n}\nint16_t int16FromFloat(highp float x) {\n return int16_t(int(clamp(x, -32768.0, 32767.0)));\n}\n`,\n];\n\nexport const glsl_uint32 = [\n glsl_uint64,\n `\nstruct uint32_t {\n highp uint value;\n};\nuint32_t mixLinear(uint32_t x, uint32_t y, highp float a) {\n return uint32_t(uint(round(mix(float(x.value), float(y.value), a))));\n}\nhighp float toNormalized(uint32_t x) { return float(x.value) / 4294967295.0; }\nhighp uint toRaw(uint32_t x) { return x.value; }\nuint64_t toUint64(uint32_t x) {\n uint64_t result;\n result.value[0] = x.value;\n result.value[1] = 0u;\n return result;\n}\nuint32_t uint32FromFloat(highp float x) {\n return uint32_t(uint(clamp(x, 0.0, 4294967295.0)));\n}\n`,\n];\n\nexport const glsl_int32 = [\n glsl_uint64,\n `\nstruct int32_t {\n highp int value;\n};\nint32_t mixLinear(int32_t x, int32_t y, highp float a) {\n return int32_t(int(round(mix(float(x.value), float(y.value), a))));\n}\nhighp int toRaw(int32_t x) { return x.value; }\nuint64_t toUint64(int32_t x) {\n uint64_t result;\n result.value[0] = uint(x.value);\n result.value[1] = uint(x.value >> 31);\n return result;\n}\nint32_t int32FromFloat(highp float x) {\n return int32_t(int(clamp(x, 2147483648.0, 2147483647.0)));\n}\n`,\n];\n\nexport const glsl_getFortranOrderIndex = `\nhighp int getFortranOrderIndex(ivec3 subscripts, ivec3 size) {\n return subscripts.x + size.x * (subscripts.y + size.y * subscripts.z);\n}\n`;\n\nexport const glsl_log2Exact = `\nhighp uint log2Exact(highp uint i) {\n highp uint r;\n r = uint((i & 0xAAAAAAAAu) != 0u);\n r |= uint((i & 0xFFFF0000u) != 0u) << 4;\n r |= uint((i & 0xFF00FF00u) != 0u) << 3;\n r |= uint((i & 0xF0F0F0F0u) != 0u) << 2;\n r |= uint((i & 0xCCCCCCCCu) != 0u) << 1;\n return r;\n}\n`;\n\n// Clip line endpoints to the OpenGL viewing volume depth range.\n// https://www.khronos.org/opengl/wiki/Vertex_Post-Processing#Clipping\n//\n// This is similar to the clipping that the OpenGL implementation itself would do for lines, except\n// that we only clip based on `z`.\nexport const glsl_clipLineToDepthRange = `\nbool clipLineToDepthRange(inout highp vec4 a, inout highp vec4 b) {\n highp float tmin = 0.0, tmax = 1.0;\n highp float k1 = b.w - a.w + a.z - b.z;\n highp float k2 = a.w - b.w + a.z - b.z;\n highp float q1 = (a.z - a.w) / k1;\n highp float q2 = (a.z + a.w) / k2;\n if (k1 > 0.0) tmin = max(tmin, q1);\n else if (k1 < 0.0) tmax = min(tmax, q1);\n if (k2 > 0.0) tmax = min(tmax, q2);\n else if (k2 < 0.0) tmin = max(tmin, q2);\n if (tmin <= tmax) {\n highp vec4 tempA = a;\n highp vec4 tempB = b;\n a = mix(tempA, tempB, tmin);\n b = mix(tempA, tempB, tmax);\n return true;\n }\n return false;\n}\n`;\n\n// https://stackoverflow.com/questions/4200224/random-noise-functions-for-glsl\nexport const glsl_simpleFloatHash = `\nhighp float simpleFloatHash(highp vec2 co) {\n return fract(sin(dot(co.xy ,vec2(12.9898,78.233))) * 43758.5453);\n}\n`;\n\nexport const glsl_shiftLeftSaturateUint32 = `\nhighp uint shiftLeftSaturate(highp uint x, int shiftAmount) {\n highp uint result = x << shiftAmount;\n if ((result >> shiftAmount) != x) return 0xffffffffu;\n return result;\n}\n`;\n\nexport const glsl_addSaturateUint32 = `\nhighp uint addSaturate(highp uint x, highp uint y) {\n highp uint result = x + y;\n if (result < x) return 0xffffffffu;\n return result;\n}\n`;\n\nexport const glsl_subtractSaturateUint32 = `\nhighp uint subtractSaturate(highp uint x, highp uint y) {\n highp uint result = x - y;\n if (result > x) return 0u;\n return result;\n}\n`;\n\nexport const glsl_addSaturateInt32 = [\n glsl_addSaturateUint32,\n `\nhighp int addSaturate(highp int x, highp uint y) {\n if (x >= 0) {\n return int(min(addSaturate(y, uint(x)), 0x7fffffffu));\n } else if (y >= uint(-x)) {\n return int(min(y - uint(-x), 0x7fffffffu));\n } else {\n return -int(min(uint(-x) - y, 0x80000000u));\n }\n}\n`,\n];\n\nexport const glsl_subtractSaturateInt32 = [\n glsl_addSaturateUint32,\n `\nhighp int subtractSaturate(highp int x, highp uint y) {\n if (x < 0) {\n return -int(min(addSaturate(uint(-x), uint(y)), 0x80000000u));\n } else if (uint(x) >= y) {\n return x - int(y);\n } else {\n return -int(min(y - uint(x), 0x80000000u));\n }\n}\n`,\n];\n\nexport function getShaderType(dataType: DataType, numComponents = 1) {\n switch (dataType) {\n case DataType.FLOAT32:\n if (numComponents === 1) {\n return \"float\";\n }\n if (numComponents > 1 && numComponents <= 4) {\n return `vec${numComponents}`;\n }\n break;\n case DataType.UINT8:\n case DataType.INT8:\n case DataType.UINT16:\n case DataType.INT16:\n case DataType.UINT32:\n case DataType.INT32:\n case DataType.UINT64: {\n const prefix = DATA_TYPE_SIGNED[dataType] ? \"\" : \"u\";\n const bits = DATA_TYPE_BYTES[dataType] * 8;\n if (numComponents === 1) {\n return `${prefix}int${bits}_t`;\n }\n if (numComponents > 1 && numComponents * bits <= 32) {\n return `${prefix}int${bits}x${numComponents}_t`;\n }\n break;\n }\n }\n throw new Error(\n `No shader type for ${DataType[dataType]}[${numComponents}].`,\n );\n}\n\nexport const dataTypeShaderDefinition: Record = {\n [DataType.UINT8]: glsl_uint8,\n [DataType.INT8]: glsl_int8,\n [DataType.UINT16]: glsl_uint16,\n [DataType.INT16]: glsl_int16,\n [DataType.UINT32]: glsl_uint32,\n [DataType.INT32]: glsl_int32,\n [DataType.UINT64]: glsl_uint64,\n [DataType.FLOAT32]: glsl_float,\n};\n\nexport function getShaderVectorType(\n typeName: \"float\" | \"int\" | \"uint\",\n n: number,\n) {\n if (n === 1) return typeName;\n if (typeName === \"float\") return `vec${n}`;\n return `${typeName[0]}vec${n}`;\n}\n\nexport const webglTypeSizeInBytes: { [webglType: number]: number } = {\n [WebGL2RenderingContext.UNSIGNED_BYTE]: 1,\n [WebGL2RenderingContext.BYTE]: 1,\n [WebGL2RenderingContext.UNSIGNED_SHORT]: 2,\n [WebGL2RenderingContext.SHORT]: 2,\n [WebGL2RenderingContext.FLOAT]: 4,\n [WebGL2RenderingContext.INT]: 4,\n [WebGL2RenderingContext.UNSIGNED_INT]: 4,\n};\n\nexport function defineVectorArrayVertexShaderInput(\n builder: ShaderBuilder,\n typeName: \"float\" | \"int\" | \"uint\",\n attributeType: number,\n normalized: boolean,\n name: string,\n vectorRank: number,\n arraySize = 1,\n) {\n let numAttributes = 0;\n let n = vectorRank * arraySize;\n while (n > 0) {\n const components = Math.min(4, n);\n const t = getShaderVectorType(typeName, components);\n n -= components;\n builder.addAttribute(\"highp \" + t, `a${name}${numAttributes}`);\n ++numAttributes;\n }\n n = vectorRank * arraySize;\n let code = \"\";\n for (let arrayIndex = 0; arrayIndex < arraySize; ++arrayIndex) {\n code += `highp ${typeName}[${vectorRank}] get${name}${arrayIndex}() {\n highp ${typeName}[${vectorRank}] result;\n`;\n for (let vectorIndex = 0; vectorIndex < vectorRank; ++vectorIndex) {\n const i = arrayIndex * vectorRank + vectorIndex;\n const attributeIndex = Math.floor(i / 4);\n const componentIndex = i % 4;\n code += ` result[${vectorIndex}] = a${name}${attributeIndex}`;\n if (componentIndex !== 0 || i !== n - 1) {\n code += `[${componentIndex}]`;\n }\n code += \";\\n\";\n }\n code += \" return result;\\n\";\n code += \"}\\n\";\n }\n builder.addVertexCode(code);\n const elementSize = webglTypeSizeInBytes[attributeType];\n builder.addInitializer((shader) => {\n const locations: AttributeIndex[] = [];\n for (\n let attributeIndex = 0;\n attributeIndex < numAttributes;\n ++attributeIndex\n ) {\n locations[attributeIndex] = shader.attribute(`a${name}${attributeIndex}`);\n }\n shader.vertexShaderInputBinders[name] = {\n enable(divisor: number) {\n const { gl } = shader;\n for (\n let attributeIndex = 0;\n attributeIndex < numAttributes;\n ++attributeIndex\n ) {\n const location = locations[attributeIndex];\n gl.enableVertexAttribArray(location);\n gl.vertexAttribDivisor(location, divisor);\n }\n },\n disable() {\n const { gl } = shader;\n for (\n let attributeIndex = 0;\n attributeIndex < numAttributes;\n ++attributeIndex\n ) {\n const location = locations[attributeIndex];\n gl.vertexAttribDivisor(location, 0);\n gl.disableVertexAttribArray(location);\n }\n },\n bind(stride: number, offset: number) {\n const { gl } = shader;\n for (\n let attributeIndex = 0;\n attributeIndex < numAttributes;\n ++attributeIndex\n ) {\n const location = locations[attributeIndex];\n const numComponents = Math.min(4, n - 4 * attributeIndex);\n if (typeName === \"float\") {\n gl.vertexAttribPointer(\n location,\n /*size=*/ numComponents,\n attributeType,\n normalized,\n stride,\n offset,\n );\n } else {\n gl.vertexAttribIPointer(\n location,\n /*size=*/ Math.min(4, n - 4 * attributeIndex),\n attributeType,\n stride,\n offset,\n );\n }\n offset += elementSize * numComponents;\n }\n },\n };\n });\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Defines facilities for GPU computation of empirical cumulative distribution functions.\n *\n * This is based on the technique described in\n * http://shaderwrangler.com/publications/histogram/\n *\n * In particular, the \"scatter\" operation required to compute a histogram is performed by\n * rendering point primitives.\n */\n\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type { DataTypeInterval } from \"#src/util/lerp.js\";\nimport { VisibilityPriorityAggregator } from \"#src/visibility_priority/frontend.js\";\nimport { getMemoizedBuffer } from \"#src/webgl/buffer.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { TextureBuffer } from \"#src/webgl/offscreen.js\";\nimport {\n FramebufferConfiguration,\n makeTextureBuffers,\n} from \"#src/webgl/offscreen.js\";\nimport { ShaderBuilder } from \"#src/webgl/shader.js\";\nimport { glsl_simpleFloatHash } from \"#src/webgl/shader_lib.js\";\nimport { setRawTextureParameters } from \"#src/webgl/texture.js\";\n\nconst DEBUG_HISTOGRAMS = false;\n\nexport interface HistogramChannelSpecification {\n // Channel coordinates.\n channel: Uint32Array;\n}\n\nexport class HistogramSpecifications extends RefCounted {\n framebuffers: FramebufferConfiguration[] = [];\n producerVisibility = new VisibilityPriorityAggregator();\n frameNumber = -1;\n constructor(\n public channels: WatchableValueInterface,\n public properties: WatchableValueInterface,\n public bounds: WatchableValueInterface,\n public visibility = new VisibilityPriorityAggregator(),\n ) {\n super();\n }\n\n getFramebuffers(gl: GL) {\n const { framebuffers } = this;\n const count = this.bounds.value.length;\n while (framebuffers.length < count) {\n const framebuffer = new FramebufferConfiguration(gl, {\n colorBuffers: makeTextureBuffers(\n gl,\n 1,\n WebGL2RenderingContext.R32F,\n WebGL2RenderingContext.RED,\n WebGL2RenderingContext.FLOAT,\n ),\n });\n framebuffers.push(framebuffer);\n }\n return framebuffers;\n }\n\n get visibleHistograms(): number {\n if (!this.visibility.visible) return 0;\n return this.bounds.value.length;\n }\n\n disposed() {\n for (const framebuffer of this.framebuffers) {\n framebuffer.dispose();\n }\n this.framebuffers.length = 0;\n }\n}\n\nconst histogramDataSamplerTextureUnit = Symbol(\n \"histogramDataSamplerTextureUnit\",\n);\nconst histogramDepthTextureUnit = Symbol(\"histogramDepthTextureUnit\");\n\nconst histogramSamplesPerInstance = 4096;\n\n// Number of points to sample in computing the histogram. Increasing this increases the precision\n// of the histogram but also slows down rendering.\nconst histogramSamples = 2 ** 14;\n\n/**\n * Generates a histogram from a single-channel uint8 texture.\n */\nexport class TextureHistogramGenerator extends RefCounted {\n private shader = this.registerDisposer(\n (() => {\n const builder = new ShaderBuilder(this.gl);\n builder.addOutputBuffer(\"vec4\", \"outputValue\", 0);\n builder.addAttribute(\"float\", \"aInput1\");\n builder.addTextureSampler(\n \"sampler2D\",\n \"uDataSampler\",\n histogramDataSamplerTextureUnit,\n );\n builder.addTextureSampler(\n \"sampler2D\",\n \"uDepthSampler\",\n histogramDepthTextureUnit,\n );\n // builder.addUniform('float', 'uRandomSeed');\n builder.addVertexCode(glsl_simpleFloatHash);\n builder.setVertexMain(`\nfloat uRandomSeed = 0.0;\nvec2 p = vec2(simpleFloatHash(vec2(aInput1 + float(gl_VertexID), uRandomSeed + float(gl_InstanceID))),\n simpleFloatHash(vec2(aInput1 + float(gl_VertexID) + 10.0, 5.0 + uRandomSeed + float(gl_InstanceID))));\nfloat dataValue = texture(uDataSampler, p).x;\nfloat stencilValue = texture(uDepthSampler, p).x;\nif (stencilValue == 1.0) {\n gl_Position = vec4(2.0, 2.0, 2.0, 1.0);\n} else {\n gl_Position = vec4(2.0 * (dataValue * 255.0 + 0.5) / 256.0 - 1.0, 0.0, 0.0, 1.0);\n}\ngl_PointSize = 1.0;\n`);\n builder.setFragmentMain(`\noutputValue = vec4(1.0, 1.0, 1.0, 1.0);\n`);\n return builder.build();\n })(),\n );\n\n private inputIndexBuffer = this.registerDisposer(\n getMemoizedBuffer(\n this.gl,\n WebGL2RenderingContext.ARRAY_BUFFER,\n () => new Uint8Array(histogramSamplesPerInstance),\n ),\n );\n\n constructor(public gl: GL) {\n super();\n }\n\n static get(gl: GL) {\n return gl.memoize.get(\n \"textureHistogramGeneration\",\n () => new TextureHistogramGenerator(gl),\n );\n }\n\n compute(\n count: number,\n depthTexture: WebGLTexture | null,\n inputTextures: TextureBuffer[],\n histogramSpecifications: HistogramSpecifications,\n frameNumber: number,\n ) {\n const { gl } = this;\n const { shader } = this;\n const outputFramebuffers = histogramSpecifications.getFramebuffers(gl);\n shader.bind();\n gl.enable(WebGL2RenderingContext.BLEND);\n gl.disable(WebGL2RenderingContext.SCISSOR_TEST);\n gl.disable(WebGL2RenderingContext.DEPTH_TEST);\n gl.blendFunc(WebGL2RenderingContext.ONE, WebGL2RenderingContext.ONE);\n this.inputIndexBuffer.value.bindToVertexAttrib(\n shader.attribute(\"aInput1\"),\n 1,\n WebGL2RenderingContext.UNSIGNED_BYTE,\n /*normalized=*/ true,\n );\n const dataUnit = shader.textureUnit(histogramDataSamplerTextureUnit);\n const depthUnit = shader.textureUnit(histogramDepthTextureUnit);\n gl.activeTexture(WebGL2RenderingContext.TEXTURE0 + depthUnit);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, depthTexture);\n setRawTextureParameters(gl);\n gl.activeTexture(WebGL2RenderingContext.TEXTURE0 + dataUnit);\n const oldFrameNumber = histogramSpecifications.frameNumber;\n histogramSpecifications.frameNumber = frameNumber;\n for (let i = 0; i < count; ++i) {\n gl.bindTexture(\n WebGL2RenderingContext.TEXTURE_2D,\n inputTextures[i].texture,\n );\n setRawTextureParameters(gl);\n outputFramebuffers[i].bind(256, 1);\n if (frameNumber !== oldFrameNumber) {\n gl.clearColor(0, 0, 0, 0);\n gl.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT);\n }\n gl.drawArraysInstanced(\n WebGL2RenderingContext.POINTS,\n 0,\n histogramSamplesPerInstance,\n histogramSamples / histogramSamplesPerInstance,\n );\n\n if (DEBUG_HISTOGRAMS) {\n const tempBuffer = new Float32Array(256 * 4);\n gl.readPixels(\n 0,\n 0,\n 256,\n 1,\n WebGL2RenderingContext.RGBA,\n WebGL2RenderingContext.FLOAT,\n tempBuffer,\n );\n const tempBuffer2 = new Float32Array(256);\n for (let j = 0; j < 256; ++j) {\n tempBuffer2[j] = tempBuffer[j * 4];\n }\n console.log(\"histogram\", tempBuffer2.join(\" \"));\n }\n }\n gl.disable(WebGL2RenderingContext.BLEND);\n }\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Defines lerp/invlerp functionality for all supported data types.\n */\n\nimport { DataType, DATA_TYPE_SIGNED } from \"#src/util/data_type.js\";\nimport type { DataTypeInterval } from \"#src/util/lerp.js\";\nimport { Uint64 } from \"#src/util/uint64.js\";\nimport type {\n ShaderBuilder,\n ShaderCodePart,\n ShaderProgram,\n} from \"#src/webgl/shader.js\";\nimport {\n dataTypeShaderDefinition,\n getShaderType,\n glsl_addSaturateInt32,\n glsl_addSaturateUint32,\n glsl_addSaturateUint64,\n glsl_compareLessThanUint64,\n glsl_equalUint64,\n glsl_shiftLeftSaturateUint32,\n glsl_shiftLeftUint64,\n glsl_shiftRightUint64,\n glsl_subtractSaturateInt32,\n glsl_subtractSaturateUint32,\n glsl_subtractSaturateUint64,\n glsl_subtractUint64,\n glsl_uint64,\n} from \"#src/webgl/shader_lib.js\";\n\nexport const dataTypeShaderLerpParametersType: Record = {\n [DataType.UINT8]: \"vec2\",\n [DataType.INT8]: \"vec2\",\n [DataType.UINT16]: \"vec2\",\n [DataType.INT16]: \"vec2\",\n [DataType.FLOAT32]: \"vec2\",\n [DataType.UINT32]: \"Uint32LerpParameters\",\n [DataType.INT32]: \"Int32LerpParameters\",\n [DataType.UINT64]: \"Uint64LerpParameters\",\n};\n\nconst glsl_dataTypeLerpParameters: Record = {\n [DataType.UINT8]: \"\",\n [DataType.INT8]: \"\",\n [DataType.UINT16]: \"\",\n [DataType.INT16]: \"\",\n [DataType.FLOAT32]: \"\",\n [DataType.UINT32]: `\nstruct Uint32LerpParameters {\n uint offset;\n int shift;\n float multiplier;\n};\n`,\n [DataType.INT32]: `\nstruct Int32LerpParameters {\n int offset;\n int shift;\n float multiplier;\n};\n`,\n [DataType.UINT64]: [\n glsl_uint64,\n `\nstruct Uint64LerpParameters {\n uint64_t offset;\n int shift;\n float multiplier;\n};\n`,\n ],\n};\n\nconst glsl_computeInvlerpFloat = `\nfloat computeInvlerp(float inputValue, vec2 p) {\n float outputValue = inputValue;\n outputValue = (outputValue - p[0]) * p[1];\n return outputValue;\n}\n`;\n\nfunction getIntFloatInvlerpImpl(dataType: DataType) {\n const shaderDataType = getShaderType(dataType);\n const code = `\nfloat computeInvlerp(${shaderDataType} inputValue, vec2 p) {\n return computeInvlerp(float(toRaw(inputValue)), p);\n}\n`;\n return [dataTypeShaderDefinition[dataType], glsl_computeInvlerpFloat, code];\n}\n\nfunction getInt32InvlerpImpl(dataType: DataType) {\n const shaderDataType = getShaderType(dataType);\n const scalarType = dataType === DataType.INT32 ? \"int\" : \"uint\";\n const pType = dataTypeShaderLerpParametersType[dataType];\n return [\n dataTypeShaderDefinition[dataType],\n glsl_dataTypeLerpParameters[dataType],\n `\nfloat computeInvlerp(${scalarType} v, ${pType} p) {\n uint x;\n if (v >= p.offset) {\n x = uint(v - p.offset);\n } else {\n x = uint(p.offset - v);\n p.multiplier = -p.multiplier;\n }\n x >>= p.shift;\n return float(x) * p.multiplier;\n}\nfloat computeInvlerp(${shaderDataType} inputValue, ${pType} p) {\n return computeInvlerp(toRaw(inputValue), p);\n}\n`,\n ];\n}\n\nexport const glsl_dataTypeComputeInvlerp: Record = {\n [DataType.UINT8]: getIntFloatInvlerpImpl(DataType.UINT8),\n [DataType.INT8]: getIntFloatInvlerpImpl(DataType.INT8),\n [DataType.UINT16]: getIntFloatInvlerpImpl(DataType.UINT16),\n [DataType.INT16]: getIntFloatInvlerpImpl(DataType.INT16),\n [DataType.FLOAT32]: glsl_computeInvlerpFloat,\n [DataType.UINT32]: getInt32InvlerpImpl(DataType.UINT32),\n [DataType.INT32]: getInt32InvlerpImpl(DataType.INT32),\n [DataType.UINT64]: [\n glsl_uint64,\n glsl_compareLessThanUint64,\n glsl_subtractUint64,\n glsl_shiftRightUint64,\n glsl_dataTypeLerpParameters[DataType.UINT64],\n `\nfloat computeInvlerp(uint64_t inputValue, Uint64LerpParameters p) {\n if (compareLessThan(inputValue, p.offset)) {\n inputValue = subtract(p.offset, inputValue);\n p.multiplier = -p.multiplier;\n } else {\n inputValue = subtract(inputValue, p.offset);\n }\n uint shifted = shiftRight(inputValue, p.shift).value[0];\n return float(shifted) * p.multiplier;\n}\n`,\n ],\n};\n\nfunction getFloatLerpImpl(dataType: DataType) {\n const shaderDataType = getShaderType(dataType);\n let code = `\n${shaderDataType} computeLerp(float inputValue, vec2 p) {\n inputValue = inputValue / p[1] + p[0];\n`;\n if (dataType === DataType.FLOAT32) {\n code += \"return inputValue;\\n\";\n } else {\n code += `return ${DataType[\n dataType\n ].toLowerCase()}FromFloat(round(inputValue));\\n`;\n }\n code += `\n}\n`;\n return [dataTypeShaderDefinition[dataType], code];\n}\n\nfunction getInt32LerpImpl(dataType: DataType) {\n const shaderDataType = getShaderType(dataType);\n const pType = dataTypeShaderLerpParametersType[dataType];\n return [\n dataTypeShaderDefinition[dataType],\n glsl_dataTypeLerpParameters[dataType],\n glsl_shiftLeftSaturateUint32,\n dataType === DataType.UINT32\n ? glsl_addSaturateUint32\n : glsl_addSaturateInt32,\n dataType === DataType.UINT32\n ? glsl_subtractSaturateUint32\n : glsl_subtractSaturateInt32,\n `\n${shaderDataType} computeLerp(float inputValue, ${pType} p) {\n inputValue = inputValue / p.multiplier;\n uint x = uint(clamp(round(abs(inputValue)), 0.0, 4294967295.0));\n uint xShifted = shiftLeftSaturate(x, p.shift);\n if (inputValue >= 0.0) {\n return ${shaderDataType}(addSaturate(p.offset, xShifted));\n } else {\n return ${shaderDataType}(subtractSaturate(p.offset, xShifted));\n }\n}\n`,\n ];\n}\n\nexport const glsl_dataTypeComputeLerp: Record = {\n [DataType.UINT8]: getFloatLerpImpl(DataType.UINT8),\n [DataType.INT8]: getFloatLerpImpl(DataType.INT8),\n [DataType.UINT16]: getFloatLerpImpl(DataType.UINT16),\n [DataType.INT16]: getFloatLerpImpl(DataType.INT16),\n [DataType.FLOAT32]: getFloatLerpImpl(DataType.FLOAT32),\n [DataType.UINT32]: getInt32LerpImpl(DataType.UINT32),\n [DataType.INT32]: getInt32LerpImpl(DataType.INT32),\n [DataType.UINT64]: [\n glsl_uint64,\n glsl_compareLessThanUint64,\n glsl_equalUint64,\n glsl_addSaturateUint64,\n glsl_subtractSaturateUint64,\n glsl_shiftRightUint64,\n glsl_shiftLeftUint64,\n glsl_dataTypeLerpParameters[DataType.UINT64],\n `\nuint64_t computeLerp(float inputValue, Uint64LerpParameters p) {\n inputValue = inputValue / p.multiplier;\n uint64_t x = uint64_t(uvec2(uint(clamp(round(abs(inputValue)), 0.0, 4294967295.0)), 0u));\n uint64_t shifted = shiftLeft(x, p.shift);\n if (!equals(shiftRight(shifted, p.shift), x)) {\n return uint64_t(uvec2(0xffffffffu, 0xffffffffu));\n }\n if (inputValue >= 0.0) {\n return addSaturate(p.offset, shifted);\n } else {\n return subtractSaturate(p.offset, shifted);\n }\n}\n`,\n ],\n};\n\nfunction defineLerpUniforms(\n builder: ShaderBuilder,\n name: string,\n dataType: DataType,\n): ShaderCodePart {\n const pName = `uLerpParams_${name}`;\n const bName = `uLerpBounds_${name}`;\n const sName = `uLerpScalar_${name}`;\n let code = \"\";\n switch (dataType) {\n case DataType.INT8:\n case DataType.UINT8:\n case DataType.INT16:\n case DataType.UINT16:\n // {uint,int}{8,16} can be converted with float32 without any loss of precision\n // fallthrough\n case DataType.FLOAT32:\n builder.addUniform(\"vec2\", pName);\n break;\n case DataType.INT32:\n case DataType.UINT32: {\n const pType = dataTypeShaderLerpParametersType[dataType];\n builder.addUniform(\n `${dataType === DataType.INT32 ? \"i\" : \"u\"}vec2`,\n bName,\n );\n builder.addUniform(\"float\", sName);\n code += `\n#define ${pName} ${pType}(${bName}[0], int(${bName}[1]), ${sName})\n`;\n break;\n }\n case DataType.UINT64: {\n builder.addUniform(\"uvec3\", bName);\n builder.addUniform(\"float\", sName);\n code += `\n#define ${pName} Uint64LerpParameters(uint64_t(${bName}.xy), int(${bName}[2]), ${sName})\n`;\n break;\n }\n }\n return [glsl_dataTypeLerpParameters[dataType], code];\n}\n\nexport function defineInvlerpShaderFunction(\n builder: ShaderBuilder,\n name: string,\n dataType: DataType,\n clamp = false,\n): ShaderCodePart {\n const shaderType = getShaderType(dataType);\n let code = `\nfloat ${name}(${shaderType} inputValue) {\n float v = computeInvlerp(inputValue, uLerpParams_${name});\n ${!clamp ? \"\" : \"v = clamp(v, 0.0, 1.0);\"}\n defaultMaxProjectionIntensity = v;\n return v;\n}\n`;\n if (dataType !== DataType.UINT64 && dataType !== DataType.FLOAT32) {\n const scalarType = DATA_TYPE_SIGNED[dataType] ? \"int\" : \"uint\";\n code += `\nfloat ${name}(${scalarType} inputValue) {\n return ${name}(${shaderType}(inputValue));\n}\n`;\n }\n return [\n dataTypeShaderDefinition[dataType],\n defineLerpUniforms(builder, name, dataType),\n glsl_dataTypeComputeInvlerp[dataType],\n code,\n ];\n}\n\nexport function defineLerpShaderFunction(\n builder: ShaderBuilder,\n name: string,\n dataType: DataType,\n): ShaderCodePart {\n return [\n dataTypeShaderDefinition[dataType],\n defineLerpUniforms(builder, name, dataType),\n glsl_dataTypeComputeLerp[dataType],\n `\n${getShaderType(dataType)} ${name}(float inputValue) {\n return computeLerp(inputValue, uLerpParams_${name});\n}\n`,\n ];\n}\n\nconst tempUint64 = new Uint64();\n\nexport function enableLerpShaderFunction(\n shader: ShaderProgram,\n name: string,\n dataType: DataType,\n interval: DataTypeInterval,\n) {\n const { gl } = shader;\n switch (dataType) {\n case DataType.INT8:\n case DataType.UINT8:\n case DataType.INT16:\n case DataType.UINT16:\n case DataType.FLOAT32:\n gl.uniform2f(\n shader.uniform(`uLerpParams_${name}`),\n interval[0] as number,\n 1 / ((interval[1] as number) - (interval[0] as number)),\n );\n break;\n case DataType.INT32:\n case DataType.UINT32: {\n const lower = interval[0] as number;\n const diff = (interval[1] as number) - lower;\n const shift = Math.max(0, Math.ceil(Math.log2(Math.abs(diff))) - 24);\n const scalar = 2 ** shift / diff;\n const bLocation = shader.uniform(`uLerpBounds_${name}`);\n if (dataType === DataType.UINT32) {\n gl.uniform2ui(bLocation, lower, shift);\n } else {\n gl.uniform2i(bLocation, lower, shift);\n }\n gl.uniform1f(shader.uniform(`uLerpScalar_${name}`), scalar);\n break;\n }\n case DataType.UINT64: {\n const lower = interval[0] as Uint64;\n const upper = interval[1] as Uint64;\n Uint64.absDifference(tempUint64, upper, lower);\n const numBits =\n tempUint64.high > 0\n ? 32 + Math.ceil(Math.log2(tempUint64.high))\n : Math.ceil(Math.log2(tempUint64.low));\n const shift = Math.max(0, numBits - 24);\n Uint64.rshift(tempUint64, tempUint64, shift);\n let scalar = 1 / tempUint64.low;\n if (Uint64.compare(lower, upper) > 0) {\n scalar *= -1;\n }\n const bLocation = shader.uniform(`uLerpBounds_${name}`);\n gl.uniform3ui(bLocation, lower.low, lower.high, shift);\n gl.uniform1f(shader.uniform(`uLerpScalar_${name}`), scalar);\n }\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Defines a generic interface for a simple state tracking mechanism.\n */\n\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { verifyObject, verifyOptionalObjectProperty } from \"#src/util/json.js\";\nimport type { NullaryReadonlySignal } from \"#src/util/signal.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\n\nexport interface JsonRestorable {\n restoreState: (x: any) => void;\n}\n\nexport function optionallyRestoreFromJsonMember(\n obj: any,\n member: string,\n restorable: JsonRestorable,\n) {\n verifyOptionalObjectProperty(obj, member, (x) => restorable.restoreState(x));\n}\n\nexport interface Trackable extends JsonRestorable {\n restoreState: (x: any) => void;\n reset: () => void;\n changed: NullaryReadonlySignal;\n toJSON: () => any;\n}\n\nexport class CompoundTrackable extends RefCounted implements Trackable {\n children = new Map();\n changed = new NullarySignal();\n\n add(key: string, value: Trackable): () => void {\n const { children } = this;\n if (children.has(key)) {\n throw new Error(`Key ${JSON.stringify(key)} already registered.`);\n }\n this.children.set(key, value);\n value.changed.add(this.changed.dispatch);\n this.changed.dispatch();\n return () => {\n this.remove(key);\n };\n }\n\n remove(key: string): void {\n const { children } = this;\n if (children.has(key)) {\n throw new Error(`Key ${JSON.stringify(key)} not registered.`);\n }\n const value = children.get(key)!;\n this.children.delete(key);\n value.changed.remove(this.changed.dispatch);\n this.changed.dispatch();\n }\n\n disposed() {\n const { changed } = this;\n for (const value of this.children.values()) {\n value.changed.remove(changed.dispatch);\n }\n this.children = undefined;\n super.disposed();\n }\n\n toJSON() {\n const result = this.baseJSON();\n for (const [key, value] of this.children) {\n result[key] = value.toJSON();\n }\n return result;\n }\n\n baseJSON() {\n return <{ [key: string]: any }>{};\n }\n\n reset() {\n for (const value of this.children.values()) {\n value.reset();\n }\n }\n\n restoreState(x: any) {\n verifyObject(x);\n for (const [key, value] of this.children) {\n try {\n if (Object.prototype.hasOwnProperty.call(x, key)) {\n const subValue = x[key];\n if (subValue === undefined) {\n continue;\n }\n value.restoreState(subValue);\n }\n } catch (restoreError) {\n throw new Error(\n `Error restoring property ${JSON.stringify(key)}: ${\n restoreError.message\n }`,\n );\n }\n }\n }\n}\n\nexport class PersistentCompoundTrackable extends CompoundTrackable {\n lastState: { [key: string]: any } = {};\n\n restoreState(x: any) {\n verifyObject(x);\n this.lastState = x;\n super.restoreState(x);\n }\n\n reset() {\n this.lastState = {};\n super.reset();\n }\n\n baseJSON() {\n const result = Object.assign(super.baseJSON(), this.lastState);\n for (const key of this.children.keys()) {\n delete result[key];\n }\n return result;\n }\n\n toJSON() {\n const result = super.toJSON();\n this.lastState = result;\n return result;\n }\n add(key: string, value: Trackable) {\n const result = super.add(key, value);\n const existingValue = this.lastState[key];\n if (existingValue !== undefined) {\n value.reset();\n value.restoreState(existingValue);\n }\n return result;\n }\n}\n\n/**\n * Cache used by getCachedJson.\n */\nconst jsonCache = new WeakMap();\n\n/**\n * Returns a JSON representation of a Trackable object.\n *\n * Recursively caches the result, such that it is only necessary to traverse the changed portions of\n * the object.\n *\n * The returned value must not be modified.\n */\nexport function getCachedJson(root: Trackable): {\n value: any;\n generation: number;\n} {\n let cacheState = jsonCache.get(root);\n const generation = root.changed.count;\n if (cacheState !== undefined) {\n if (cacheState.generation === generation) {\n return cacheState;\n }\n }\n let value: any;\n if (root instanceof CompoundTrackable) {\n value = root.baseJSON();\n for (const [k, v] of root.children) {\n value[k] = getCachedJson(v).value;\n }\n } else {\n value = root.toJSON();\n }\n if (cacheState === undefined) {\n cacheState = { generation, value };\n jsonCache.set(root, cacheState);\n } else {\n cacheState.generation = generation;\n cacheState.value = value;\n }\n return cacheState;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type {\n CoordinateSpace,\n DimensionId,\n} from \"#src/coordinate_transform.js\";\nimport {\n clampAndRoundCoordinateToVoxelCenter,\n dimensionNamesFromJson,\n emptyInvalidCoordinateSpace,\n getBoundingBoxCenter,\n getCenterBound,\n} from \"#src/coordinate_transform.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { arraysEqual } from \"#src/util/array.js\";\nimport type { Borrowed, Owned } from \"#src/util/disposable.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { mat3, mat4, quat, vec3 } from \"#src/util/geom.js\";\nimport {\n parseArray,\n parseFiniteVec,\n verifyBoolean,\n verifyEnumString,\n verifyFiniteFloat,\n verifyFinitePositiveFloat,\n verifyObject,\n verifyObjectProperty,\n verifyOptionalObjectProperty,\n} from \"#src/util/json.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport type { Trackable } from \"#src/util/trackable.js\";\nimport { optionallyRestoreFromJsonMember } from \"#src/util/trackable.js\";\nimport { TrackableEnum } from \"#src/util/trackable_enum.js\";\nimport * as vector from \"#src/util/vector.js\";\n\nexport enum NavigationLinkType {\n LINKED = 0,\n RELATIVE = 1,\n UNLINKED = 2,\n}\n\nexport enum NavigationSimpleLinkType {\n LINKED = 0,\n UNLINKED = 2,\n}\n\nexport class TrackableNavigationLink extends TrackableEnum {\n constructor(value = NavigationLinkType.LINKED) {\n super(NavigationLinkType, value);\n }\n}\n\nexport class TrackableNavigationSimpleLink extends TrackableEnum {\n constructor(value = NavigationSimpleLinkType.LINKED) {\n super(NavigationSimpleLinkType, value);\n }\n}\n\nconst tempVec3 = vec3.create();\nconst tempQuat = quat.create();\n\nfunction makeLinked<\n T extends RefCounted & { changed: NullarySignal },\n Difference,\n>(\n self: T,\n peer: T,\n link: TrackableNavigationLink,\n operations: {\n assign: (target: T, source: T) => void;\n isValid: (a: T) => boolean;\n difference: (a: T, b: T) => Difference;\n add: (target: T, source: T, amount: Difference) => void;\n subtract: (target: T, source: T, amount: Difference) => void;\n },\n): T {\n let updatingSelf = false;\n const updatingPeer = false;\n let selfMinusPeer: Difference | undefined;\n self.registerDisposer(peer);\n const handlePeerUpdate = () => {\n if (updatingPeer) {\n return;\n }\n updatingSelf = true;\n switch (link.value) {\n case NavigationLinkType.UNLINKED:\n if (operations.isValid(self)) {\n break;\n }\n // fallthrough\n case NavigationLinkType.LINKED:\n operations.assign(self, peer);\n break;\n case NavigationLinkType.RELATIVE:\n operations.add(self, peer, selfMinusPeer!);\n break;\n }\n updatingSelf = false;\n };\n const handleSelfUpdate = () => {\n if (updatingSelf) {\n return;\n }\n switch (link.value) {\n case NavigationLinkType.UNLINKED:\n break;\n case NavigationLinkType.LINKED:\n operations.assign(peer, self);\n break;\n case NavigationLinkType.RELATIVE:\n operations.subtract(peer, self, selfMinusPeer!);\n break;\n }\n };\n let previousLinkValue = NavigationLinkType.UNLINKED;\n const handleLinkUpdate = () => {\n const linkValue = link.value;\n if (linkValue !== previousLinkValue) {\n switch (linkValue) {\n case NavigationLinkType.UNLINKED:\n selfMinusPeer = undefined;\n break;\n case NavigationLinkType.LINKED:\n selfMinusPeer = undefined;\n operations.assign(self, peer);\n break;\n case NavigationLinkType.RELATIVE:\n selfMinusPeer = operations.difference(self, peer);\n break;\n }\n }\n previousLinkValue = linkValue;\n self.changed.dispatch();\n };\n self.registerDisposer(self.changed.add(handleSelfUpdate));\n self.registerDisposer(peer.changed.add(handlePeerUpdate));\n self.registerDisposer(link.changed.add(handleLinkUpdate));\n handleLinkUpdate();\n return self;\n}\n\nfunction makeSimpleLinked(\n self: T,\n peer: T,\n link: TrackableNavigationSimpleLink,\n operations: {\n assign: (target: T, source: T) => void;\n isValid: (a: T) => boolean;\n },\n) {\n return makeLinked(self, peer, link as any, operations as any);\n}\n\nexport class Position extends RefCounted {\n private coordinates_: Float32Array = vector.kEmptyFloat32Vec;\n private curCoordinateSpace: CoordinateSpace | undefined;\n changed = new NullarySignal();\n constructor(\n public coordinateSpace: WatchableValueInterface,\n ) {\n super();\n this.registerDisposer(\n coordinateSpace.changed.add(() => {\n this.handleCoordinateSpaceChanged();\n }),\n );\n }\n\n get valid() {\n return this.coordinateSpace.value.valid;\n }\n\n /**\n * Returns the position in voxels.\n */\n get value() {\n this.handleCoordinateSpaceChanged();\n return this.coordinates_;\n }\n\n reset() {\n this.curCoordinateSpace = undefined;\n this.coordinates_ = vector.kEmptyFloat32Vec;\n this.changed.dispatch();\n }\n\n set value(coordinates: Float32Array) {\n const { curCoordinateSpace } = this;\n if (\n curCoordinateSpace === undefined ||\n !curCoordinateSpace.valid ||\n curCoordinateSpace.rank !== coordinates.length\n ) {\n return;\n }\n const { coordinates_ } = this;\n coordinates_.set(coordinates);\n this.changed.dispatch();\n }\n\n private handleCoordinateSpaceChanged() {\n const coordinateSpace = this.coordinateSpace.value;\n const prevCoordinateSpace = this.curCoordinateSpace;\n if (coordinateSpace === prevCoordinateSpace) return;\n this.curCoordinateSpace = coordinateSpace;\n const { rank } = coordinateSpace;\n if (!coordinateSpace.valid) return;\n if (prevCoordinateSpace === undefined || !prevCoordinateSpace.valid) {\n let { coordinates_ } = this;\n if (coordinates_ !== undefined && coordinates_.length === rank) {\n // Use the existing voxel coordinates if rank is the same. Otherwise, ignore.\n } else {\n coordinates_ = this.coordinates_ = new Float32Array(rank);\n getBoundingBoxCenter(coordinates_, coordinateSpace.bounds);\n const { voxelCenterAtIntegerCoordinates } = coordinateSpace.bounds;\n for (let i = 0; i < rank; ++i) {\n if (voxelCenterAtIntegerCoordinates[i]) {\n coordinates_[i] = Math.round(coordinates_[i]);\n } else {\n coordinates_[i] = Math.floor(coordinates_[i]) + 0.5;\n }\n }\n }\n this.changed.dispatch();\n return;\n }\n // Match dimensions by ID.\n const newCoordinates = new Float32Array(rank);\n const prevCoordinates = this.coordinates_;\n const { ids, scales: newScales } = coordinateSpace;\n const { ids: prevDimensionIds, scales: oldScales } = prevCoordinateSpace;\n for (let newDim = 0; newDim < rank; ++newDim) {\n const newDimId = ids[newDim];\n const oldDim = prevDimensionIds.indexOf(newDimId);\n if (oldDim === -1) {\n newCoordinates[newDim] = getCenterBound(\n coordinateSpace.bounds.lowerBounds[newDim],\n coordinateSpace.bounds.upperBounds[newDim],\n );\n } else {\n newCoordinates[newDim] =\n prevCoordinates[oldDim] * (oldScales[oldDim] / newScales[newDim]);\n }\n }\n this.coordinates_ = newCoordinates;\n this.changed.dispatch();\n }\n\n toJSON() {\n if (!this.valid && this.coordinates_.length === 0) return undefined;\n this.handleCoordinateSpaceChanged();\n const { value } = this;\n if (value.length === 0) return undefined;\n return Array.from(value);\n }\n\n restoreState(obj: any) {\n if (obj === undefined) {\n this.reset();\n return;\n }\n this.curCoordinateSpace = undefined;\n this.coordinates_ = Float32Array.from(parseArray(obj, verifyFiniteFloat));\n this.handleCoordinateSpaceChanged();\n this.changed.dispatch();\n }\n\n snapToVoxel() {\n this.handleCoordinateSpaceChanged();\n const {\n bounds: { voxelCenterAtIntegerCoordinates },\n } = this.coordinateSpace.value;\n const { coordinates_ } = this;\n const rank = coordinates_.length;\n for (let i = 0; i < rank; ++i) {\n if (voxelCenterAtIntegerCoordinates[i]) {\n coordinates_[i] = Math.round(coordinates_[i]);\n } else {\n coordinates_[i] = Math.floor(coordinates_[i]) + 0.5;\n }\n }\n this.changed.dispatch();\n }\n\n assign(other: Borrowed) {\n other.handleCoordinateSpaceChanged();\n const { curCoordinateSpace, coordinates_ } = other;\n this.curCoordinateSpace = curCoordinateSpace;\n this.coordinates_ = Float32Array.from(coordinates_);\n this.changed.dispatch();\n }\n\n /**\n * Get the offset of `a` relative to `b`.\n */\n static getOffset(a: Position, b: Position): Float32Array | undefined {\n const aCoordinates = a.coordinates_;\n const bCoordinates = b.coordinates_;\n const rank = aCoordinates.length;\n if (rank === bCoordinates.length) {\n return vector.subtract(\n new Float32Array(aCoordinates.length),\n aCoordinates,\n bCoordinates,\n );\n }\n return undefined;\n }\n static addOffset(\n target: Position,\n source: Position,\n offset: Float32Array | undefined,\n scale = 1,\n ): void {\n target.handleCoordinateSpaceChanged();\n const { value: sourceCoordinates } = source;\n if (offset !== undefined && sourceCoordinates.length === offset.length) {\n vector.scaleAndAdd(target.value, sourceCoordinates, offset, scale);\n target.changed.dispatch();\n }\n }\n\n get legacyJsonView() {\n const self = this;\n return {\n changed: self.changed,\n toJSON() {\n return self.toJSON();\n },\n reset() {\n self.reset();\n },\n restoreState(obj: unknown) {\n if (obj === undefined || Array.isArray(obj)) {\n self.restoreState(obj);\n return;\n }\n verifyObject(obj);\n optionallyRestoreFromJsonMember(obj, \"voxelCoordinates\", self);\n },\n };\n }\n}\n\nexport enum VelocityBoundaryBehavior {\n STOP = 0,\n LOOP = 1,\n REVERSE = 2,\n}\n\nexport const DEFAULT_PLAYBACK_VELOCITY = 10;\n\nexport class DimensionPlaybackVelocity {\n // Velocity in global coordinates per second.\n velocity: number = DEFAULT_PLAYBACK_VELOCITY;\n atBoundary: VelocityBoundaryBehavior = VelocityBoundaryBehavior.REVERSE;\n paused = true;\n}\n\nexport function dimensionVelocitiesEqual(\n a: DimensionPlaybackVelocity,\n b: DimensionPlaybackVelocity,\n): boolean {\n return (\n a.velocity === b.velocity &&\n a.atBoundary === b.atBoundary &&\n a.paused === b.paused\n );\n}\n\nfunction dimensionVelocityFromJson(obj: unknown) {\n verifyObject(obj);\n return {\n velocity: verifyOptionalObjectProperty(\n obj,\n \"velocity\",\n verifyFiniteFloat,\n DEFAULT_PLAYBACK_VELOCITY,\n ),\n atBoundary: verifyOptionalObjectProperty(\n obj,\n \"atBoundary\",\n (value) => verifyEnumString(value, VelocityBoundaryBehavior),\n VelocityBoundaryBehavior.STOP,\n ),\n paused: verifyOptionalObjectProperty(obj, \"paused\", verifyBoolean, true),\n };\n}\n\nfunction dimensionVelocityToJson(info: DimensionPlaybackVelocity) {\n const { velocity, atBoundary, paused } = info;\n return {\n velocity: velocity,\n atBoundary:\n atBoundary === VelocityBoundaryBehavior.STOP\n ? undefined\n : VelocityBoundaryBehavior[atBoundary].toLowerCase(),\n paused: paused ? undefined : false,\n };\n}\n\nexport class CoordinateSpacePlaybackVelocity extends RefCounted {\n private velocities_: (Readonly | undefined)[];\n private curCoordinateSpace: CoordinateSpace | undefined;\n changed = new NullarySignal();\n constructor(\n public coordinateSpace: WatchableValueInterface,\n ) {\n super();\n this.registerDisposer(\n coordinateSpace.changed.add(() => {\n this.handleCoordinateSpaceChanged();\n }),\n );\n this.curCoordinateSpace = coordinateSpace.value;\n this.velocities_ = new Array(this.curCoordinateSpace?.rank ?? 0);\n }\n\n get valid() {\n return this.coordinateSpace.value.valid;\n }\n\n get value(): (Readonly | undefined)[] {\n this.handleCoordinateSpaceChanged();\n return this.velocities_;\n }\n\n set value(velocities: (Readonly | undefined)[]) {\n const { curCoordinateSpace } = this;\n if (\n curCoordinateSpace === undefined ||\n curCoordinateSpace.rank !== velocities.length\n ) {\n return;\n }\n this.velocities_ = velocities;\n this.changed.dispatch();\n }\n\n get(id: DimensionId): DimensionPlaybackVelocity | undefined {\n const ids = this.coordinateSpace.value?.ids;\n if (ids === undefined) return;\n const index = ids.indexOf(id);\n if (index === -1) return;\n const velocities = this.value;\n return velocities[index];\n }\n\n dimensionVelocity(\n owner: RefCounted,\n id: DimensionId,\n ): WatchableValueInterface {\n const changed = new NullarySignal();\n let index = -1;\n const updateIndex = () => {\n const ids = this.coordinateSpace.value?.ids;\n if (ids === undefined) {\n index = -1;\n } else if (index === -1 || ids[index] !== id) {\n index = ids.indexOf(id);\n }\n };\n const getVelocity = () => {\n updateIndex();\n if (index === -1) return undefined;\n return this.value[index];\n };\n const setVelocity = (\n newVelocity: Readonly | undefined,\n ) => {\n updateIndex();\n if (index === -1) return;\n const velocities = this.value;\n const oldVelocity = velocities[index];\n if (oldVelocity === newVelocity) return;\n velocities[index] = newVelocity;\n this.changed.dispatch();\n };\n const prevVelocity = getVelocity();\n owner.registerDisposer(\n this.changed.add(() => {\n const curVelocity = getVelocity();\n if (curVelocity !== prevVelocity) {\n changed.dispatch();\n }\n }),\n );\n return {\n get value() {\n return getVelocity();\n },\n set value(newVelocity: Readonly | undefined) {\n setVelocity(newVelocity);\n },\n changed,\n };\n }\n\n modifyDimension(\n id: DimensionId,\n callback: (\n oldInfo: DimensionPlaybackVelocity | undefined,\n ) => DimensionPlaybackVelocity | undefined,\n ) {\n const ids = this.coordinateSpace.value?.ids;\n if (ids === undefined) return;\n const index = ids.indexOf(id);\n if (index === -1) return;\n const velocities = this.value;\n const oldInfo = velocities[index];\n const newInfo = callback(oldInfo);\n if (oldInfo === newInfo) return;\n velocities[index] = newInfo;\n this.changed.dispatch();\n }\n\n togglePlayback(id: DimensionId, newValue: boolean | undefined = undefined) {\n this.modifyDimension(id, (oldInfo = new DimensionPlaybackVelocity()) => {\n return { ...oldInfo, paused: newValue ?? !oldInfo.paused };\n });\n }\n\n playbackEnabled(id: DimensionId): WatchableValueInterface {\n const self = this;\n return {\n changed: this.changed,\n get value() {\n return self.get(id) !== undefined;\n },\n set value(enabled: boolean) {\n self.modifyDimension(id, (oldInfo) =>\n enabled ? (oldInfo ?? new DimensionPlaybackVelocity()) : undefined,\n );\n },\n };\n }\n\n multiplyVelocity(id: DimensionId, factor: number) {\n this.modifyDimension(id, (oldInfo = new DimensionPlaybackVelocity()) => {\n let newVelocity = Math.round(oldInfo.velocity * factor);\n if (newVelocity === 0) {\n newVelocity = Math.sign(oldInfo.velocity) || 1;\n }\n return { ...oldInfo, velocity: newVelocity };\n });\n }\n\n private handleCoordinateSpaceChanged() {\n const coordinateSpace = this.coordinateSpace.value;\n const prevCoordinateSpace = this.curCoordinateSpace;\n if (coordinateSpace === prevCoordinateSpace) return;\n this.curCoordinateSpace = coordinateSpace;\n const { rank } = coordinateSpace;\n if (!coordinateSpace.valid) return;\n if (prevCoordinateSpace === undefined) {\n let { velocities_ } = this;\n if (velocities_.length === rank) {\n // Use the existing velocities if rank is the same. Otherwise, ignore.\n } else {\n velocities_ = new Array<\n Readonly | undefined\n >(rank);\n }\n this.changed.dispatch();\n return;\n }\n // Match dimensions by ID.\n const newVelocities = new Array<\n Readonly | undefined\n >(rank);\n const prevVelocities = this.velocities_;\n const { ids } = coordinateSpace;\n const { ids: prevDimensionIds } = prevCoordinateSpace;\n for (let newDim = 0; newDim < rank; ++newDim) {\n const newDimId = ids[newDim];\n const oldDim = prevDimensionIds.indexOf(newDimId);\n if (oldDim !== -1) {\n newVelocities[newDim] = prevVelocities[oldDim];\n }\n }\n this.velocities_ = newVelocities;\n this.changed.dispatch();\n }\n\n toJSON() {\n this.handleCoordinateSpaceChanged();\n const { velocities_: velocities, curCoordinateSpace } = this;\n if (\n !curCoordinateSpace?.valid ||\n !velocities.some((velocity) => velocity !== undefined)\n ) {\n return undefined;\n }\n const obj: Record = {};\n const { names, rank } = curCoordinateSpace;\n for (let i = 0; i < rank; ++i) {\n const info = velocities[i];\n if (info === undefined) continue;\n obj[names[i]] = dimensionVelocityToJson(info);\n }\n return obj;\n }\n\n reset() {\n this.handleCoordinateSpaceChanged();\n this.velocities_ = new Array(this.curCoordinateSpace?.rank ?? 0);\n }\n\n restoreState(obj: any) {\n if (obj === undefined) {\n this.reset();\n return;\n }\n verifyObject(obj);\n const curCoordinateSpace = (this.curCoordinateSpace =\n this.coordinateSpace.value);\n this.velocities_ = new Array(curCoordinateSpace?.rank ?? 0);\n if (curCoordinateSpace === undefined) {\n throw new Error(\"Must specify dimensions in order to specify velocities\");\n }\n const velocities = (this.velocities_ = new Array(\n curCoordinateSpace?.rank ?? 0,\n ));\n const { names } = curCoordinateSpace;\n for (const key of Object.keys(obj)) {\n const i = names.indexOf(key);\n if (i === -1) {\n throw new Error(`Invalid dimension name: ${JSON.stringify(key)}`);\n }\n velocities[i] = verifyObjectProperty(obj, key, dimensionVelocityFromJson);\n }\n this.changed.dispatch();\n }\n\n assign(other: Borrowed) {\n const otherVelocities = other.value;\n const velocities = this.value;\n const rank = velocities.length;\n let changed = false;\n for (let i = 0; i < rank; ++i) {\n const newVelocity = otherVelocities[i];\n const curVelocity = velocities[i];\n if (newVelocity !== curVelocity) {\n if (\n curVelocity === undefined ||\n newVelocity === undefined ||\n !dimensionVelocitiesEqual(curVelocity, newVelocity)\n ) {\n changed = true;\n }\n velocities[i] = newVelocity;\n }\n }\n if (changed) {\n this.changed.dispatch();\n }\n }\n}\n\nexport class LinkedCoordinateSpacePlaybackVelocity extends RefCounted {\n changed = new NullarySignal();\n velocity = this.registerDisposer(\n new CoordinateSpacePlaybackVelocity(this.peer.coordinateSpace),\n );\n\n constructor(\n public peer: Owned,\n public positionLink: TrackableLinkInterface,\n ) {\n super();\n this.registerDisposer(peer);\n this.velocity.changed.add(() => {\n if (this.positionLink.value === NavigationLinkType.UNLINKED) {\n this.changed.dispatch();\n } else {\n this.peer.assign(this.velocity);\n }\n });\n const updateSelf = () => {\n if (this.positionLink.value !== NavigationLinkType.UNLINKED) {\n this.velocity.assign(this.peer);\n }\n };\n this.registerDisposer(peer.changed.add(updateSelf));\n updateSelf();\n }\n\n toJSON() {\n if (this.positionLink.value !== NavigationLinkType.UNLINKED) {\n return undefined;\n }\n return this.velocity.toJSON();\n }\n\n reset() {\n if (this.positionLink.value === NavigationLinkType.UNLINKED) {\n this.velocity.reset();\n }\n }\n\n restoreState(obj: unknown) {\n if (this.positionLink.value === NavigationLinkType.UNLINKED) {\n this.velocity.restoreState(obj);\n }\n }\n\n copyToPeer() {\n if (this.positionLink.value === NavigationLinkType.UNLINKED) {\n this.peer.assign(this.velocity);\n }\n }\n}\n\ninterface DimensionPlaybackState {\n dimensionIndex: number;\n prevCoordinate: number;\n prevTime: number;\n generation: number;\n}\n\nexport class PlaybackManager extends RefCounted {\n private dimensionStates = new Map();\n private lastUpdateGeneration = 0;\n private unregisterUpdateStartedCallback: (() => void) | undefined;\n\n constructor(\n public display: { updateStarted: NullarySignal; scheduleRedraw(): void },\n public position: Position,\n public velocity: CoordinateSpacePlaybackVelocity,\n ) {\n super();\n this.handleVelocityChanged();\n this.registerDisposer(\n velocity.changed.add(() => this.handleVelocityChanged()),\n );\n }\n\n disposed() {\n this.unregisterUpdateStartedCallback?.();\n super.disposed();\n }\n\n private handleVelocityChanged() {\n const { dimensionStates } = this;\n const ids = this.position.coordinateSpace.value?.ids ?? [];\n const rank = ids.length;\n const velocities = this.velocity.value;\n const generation = ++this.lastUpdateGeneration;\n const positionVector = this.position.value;\n const curTime = Date.now();\n for (let i = 0; i < rank; ++i) {\n const velocity = velocities[i];\n if (velocity === undefined) continue;\n if (velocity.velocity === 0 || velocity.paused) continue;\n const id = ids[i];\n const state = dimensionStates.get(id);\n if (state === undefined) {\n dimensionStates.set(id, {\n prevTime: curTime,\n dimensionIndex: i,\n prevCoordinate: positionVector[i],\n generation,\n });\n } else {\n state.generation = generation;\n state.dimensionIndex = i;\n }\n }\n for (const [id, state] of dimensionStates) {\n if (state.generation !== generation) {\n dimensionStates.delete(id);\n }\n }\n if (dimensionStates.size === 0) {\n const { unregisterUpdateStartedCallback } = this;\n if (unregisterUpdateStartedCallback !== undefined) {\n unregisterUpdateStartedCallback();\n this.unregisterUpdateStartedCallback = undefined;\n }\n } else {\n if (this.unregisterUpdateStartedCallback === undefined) {\n this.unregisterUpdateStartedCallback = this.display.updateStarted.add(\n () => this.updateStarted(),\n );\n this.display.scheduleRedraw();\n }\n }\n }\n\n private updateStarted() {\n const coordinateSpace = this.position.coordinateSpace.value;\n if (coordinateSpace === undefined) {\n return;\n }\n const ids = coordinateSpace.ids;\n const positionVector = this.position.value;\n let positionChanged = false;\n let velocityChanged = false;\n const curTime = Date.now();\n const velocities = this.velocity.value;\n const {\n bounds: { lowerBounds, upperBounds },\n } = coordinateSpace;\n for (const [id, dimensionState] of this.dimensionStates) {\n const { dimensionIndex } = dimensionState;\n if (ids[dimensionIndex] !== id) continue;\n const velocity = velocities[dimensionIndex];\n if (\n Math.floor(positionVector[dimensionIndex]) !==\n Math.floor(dimensionState.prevCoordinate)\n ) {\n // Pause this dimension.\n if (velocity?.paused === false) {\n velocities[dimensionIndex] = { ...velocity, paused: true };\n velocityChanged = true;\n }\n continue;\n }\n const timeDelta = curTime - dimensionState.prevTime;\n const velocityValue = velocity?.velocity ?? 0;\n const delta = (timeDelta * velocityValue) / 1000;\n if (delta === 0) continue;\n let newCoordinate = positionVector[dimensionIndex] + delta;\n const lowerBound = lowerBounds[dimensionIndex];\n const upperBound = Math.ceil(upperBounds[dimensionIndex] - 1);\n const limit = delta > 0 ? upperBound : lowerBound;\n const oppositeLimit = delta > 0 ? lowerBound : upperBound;\n const deltaSign = Math.sign(delta);\n if (\n Number.isFinite(limit) &&\n newCoordinate * deltaSign >= limit * deltaSign\n ) {\n switch (velocity!.atBoundary) {\n case VelocityBoundaryBehavior.LOOP:\n if (Number.isFinite(oppositeLimit)) {\n newCoordinate = oppositeLimit;\n break;\n }\n // fallthrough\n case VelocityBoundaryBehavior.STOP:\n velocities[dimensionIndex] = { ...velocity!, paused: true };\n velocityChanged = true;\n newCoordinate = limit;\n break;\n case VelocityBoundaryBehavior.REVERSE:\n velocities[dimensionIndex] = {\n ...velocity!,\n velocity: -velocityValue,\n };\n velocityChanged = true;\n newCoordinate = limit;\n break;\n }\n }\n positionVector[dimensionIndex] = newCoordinate;\n dimensionState.prevCoordinate = positionVector[dimensionIndex];\n dimensionState.prevTime = curTime;\n positionChanged = true;\n }\n if (positionChanged) {\n this.position.changed.dispatch();\n }\n if (velocityChanged) {\n this.velocity.changed.dispatch();\n }\n this.display.scheduleRedraw();\n }\n}\n\ntype TrackableLinkInterface =\n | TrackableNavigationLink\n | TrackableNavigationSimpleLink;\n\nfunction restoreLinkedFromJson(\n link: TrackableLinkInterface,\n value: { restoreState(obj: unknown): void },\n json: any,\n) {\n if (json === undefined || Object.keys(json).length === 0) {\n link.value = NavigationLinkType.LINKED;\n return;\n }\n verifyObject(json);\n link.value = NavigationLinkType.UNLINKED;\n verifyObjectProperty(json, \"value\", (x) => {\n if (x !== undefined) {\n value.restoreState(x);\n }\n });\n verifyObjectProperty(json, \"link\", (x) => link.restoreState(x));\n}\n\ninterface LinkableState extends RefCounted, Trackable {\n assign(other: T): void;\n}\n\nabstract class LinkedBase<\n T extends LinkableState,\n Link extends TrackableLinkInterface = TrackableNavigationLink,\n> implements Trackable\n{\n value: T;\n get changed() {\n return this.value.changed;\n }\n constructor(\n public peer: Owned,\n public link: Link = new TrackableNavigationLink() as any,\n ) {}\n\n toJSON() {\n const { link } = this;\n if (link.value === NavigationLinkType.LINKED) {\n return undefined;\n }\n return { link: link.toJSON(), value: this.getValueJson() };\n }\n\n protected getValueJson(): any {\n return this.value.toJSON();\n }\n\n reset() {\n this.link.value = NavigationLinkType.LINKED;\n }\n\n restoreState(obj: any) {\n restoreLinkedFromJson(this.link, this.value, obj);\n }\n\n copyToPeer() {\n if (this.link.value !== NavigationLinkType.LINKED) {\n this.link.value = NavigationLinkType.UNLINKED;\n this.peer.assign(this.value);\n this.link.value = NavigationLinkType.LINKED;\n }\n }\n}\n\nabstract class SimpleLinkedBase<\n T extends RefCounted & Trackable & { assign(other: T): void },\n >\n extends LinkedBase\n implements Trackable {}\n\nexport class LinkedPosition extends LinkedBase {\n value = makeLinked(\n new Position(this.peer.coordinateSpace),\n this.peer,\n this.link,\n {\n assign: (a: Position, b: Position) => a.assign(b),\n isValid: (a: Position) => {\n return a.valid;\n },\n difference: Position.getOffset,\n add: Position.addOffset,\n subtract: (\n target: Position,\n source: Position,\n amount: Float32Array | undefined,\n ) => {\n Position.addOffset(target, source, amount, -1);\n },\n },\n );\n}\n\nfunction quaternionIsIdentity(q: quat) {\n return q[0] === 0 && q[1] === 0 && q[2] === 0 && q[3] === 1;\n}\n\nexport class OrientationState extends RefCounted {\n orientation: quat;\n changed = new NullarySignal();\n\n constructor(orientation?: quat) {\n super();\n if (orientation == null) {\n orientation = quat.create();\n }\n this.orientation = orientation;\n }\n toJSON() {\n const { orientation } = this;\n quat.normalize(this.orientation, this.orientation);\n if (quaternionIsIdentity(orientation)) {\n return undefined;\n }\n return Array.prototype.slice.call(this.orientation);\n }\n restoreState(obj: any) {\n try {\n parseFiniteVec(this.orientation, obj);\n quat.normalize(this.orientation, this.orientation);\n } catch (ignoredError) {\n quat.identity(this.orientation);\n }\n this.changed.dispatch();\n }\n\n reset() {\n quat.identity(this.orientation);\n this.changed.dispatch();\n }\n\n snap() {\n const mat = mat3.create();\n mat3.fromQuat(mat, this.orientation);\n const usedAxes = [false, false, false];\n for (let i = 0; i < 3; ++i) {\n let maxComponent = 0;\n let argmaxComponent = 0;\n for (let j = 0; j < 3; ++j) {\n const value = mat[i * 3 + j];\n mat[i * 3 + j] = 0;\n if (usedAxes[j]) {\n continue;\n }\n if (Math.abs(value) > Math.abs(maxComponent)) {\n maxComponent = value;\n argmaxComponent = j;\n }\n }\n mat[i * 3 + argmaxComponent] = Math.sign(maxComponent);\n usedAxes[argmaxComponent] = true;\n }\n quat.fromMat3(this.orientation, mat);\n this.changed.dispatch();\n }\n\n /**\n * Returns a new OrientationState with orientation fixed to peerToSelf * peer.orientation. Any\n * changes to the returned OrientationState will cause a corresponding change in peer, and vice\n * versa.\n */\n static makeRelative(peer: OrientationState, peerToSelf: quat) {\n const self = new OrientationState(\n quat.multiply(quat.create(), peer.orientation, peerToSelf),\n );\n let updatingPeer = false;\n self.registerDisposer(\n peer.changed.add(() => {\n if (!updatingPeer) {\n updatingSelf = true;\n quat.multiply(self.orientation, peer.orientation, peerToSelf);\n self.changed.dispatch();\n updatingSelf = false;\n }\n }),\n );\n let updatingSelf = false;\n const selfToPeer = quat.invert(quat.create(), peerToSelf);\n self.registerDisposer(\n self.changed.add(() => {\n if (!updatingSelf) {\n updatingPeer = true;\n quat.multiply(peer.orientation, self.orientation, selfToPeer);\n peer.changed.dispatch();\n updatingPeer = false;\n }\n }),\n );\n return self;\n }\n\n assign(other: Borrowed) {\n quat.copy(this.orientation, other.orientation);\n this.changed.dispatch();\n }\n}\n\nexport class LinkedOrientationState extends LinkedBase {\n value = makeLinked(new OrientationState(), this.peer, this.link, {\n assign: (a: OrientationState, b: OrientationState) => a.assign(b),\n isValid: () => true,\n difference: (a: OrientationState, b: OrientationState) => {\n const temp = quat.create();\n return quat.multiply(\n temp,\n quat.invert(temp, b.orientation),\n a.orientation,\n );\n },\n add: (target: OrientationState, source: OrientationState, amount: quat) => {\n quat.multiply(target.orientation, source.orientation, amount);\n target.changed.dispatch();\n },\n subtract: (\n target: OrientationState,\n source: OrientationState,\n amount: quat,\n ) => {\n quat.multiply(\n target.orientation,\n source.orientation,\n quat.invert(tempQuat, amount),\n );\n target.changed.dispatch();\n },\n });\n}\n\nexport interface RelativeDisplayScales {\n /**\n * Array of length `coordinateSpace.rank` specifying scale factors on top of (will be multiply by)\n * `coordinateSpace.scales` to use for display purposes. This allows non-uniform zooming.\n */\n factors: Float64Array;\n}\n\nexport class TrackableRelativeDisplayScales\n extends RefCounted\n implements Trackable, WatchableValueInterface\n{\n changed = new NullarySignal();\n private curCoordinateSpace = emptyInvalidCoordinateSpace;\n private value_: RelativeDisplayScales = { factors: new Float64Array(0) };\n constructor(\n public coordinateSpace: WatchableValueInterface,\n ) {\n super();\n this.registerDisposer(coordinateSpace.changed.add(() => this.update()));\n this.update();\n }\n\n get value() {\n return this.update();\n }\n\n reset() {\n this.value_ = { factors: new Float64Array(0) };\n this.curCoordinateSpace = emptyInvalidCoordinateSpace;\n this.changed.dispatch();\n }\n\n toJSON() {\n const json: any = {};\n let nonEmpty = false;\n const { value } = this;\n const { factors } = value;\n const { names, rank } = this.curCoordinateSpace;\n for (let i = 0; i < rank; ++i) {\n const factor = factors[i];\n if (factor === 1) continue;\n json[names[i]] = factor;\n nonEmpty = true;\n }\n if (nonEmpty) return json;\n return undefined;\n }\n\n restoreState(json: unknown) {\n const {\n coordinateSpace: { value: coordinateSpace },\n } = this;\n const { names, rank } = coordinateSpace;\n const factors = new Float64Array(rank);\n factors.fill(-1);\n if (json !== undefined) {\n const obj = verifyObject(json);\n for (let i = 0; i < rank; ++i) {\n factors[i] = verifyObjectProperty(obj, names[i], (x) =>\n x === undefined ? 1 : verifyFinitePositiveFloat(x),\n );\n }\n }\n this.value_ = { factors };\n this.curCoordinateSpace = coordinateSpace;\n this.changed.dispatch();\n }\n\n setFactors(factors: Float64Array) {\n const {\n coordinateSpace: { value: coordinateSpace },\n } = this;\n if (factors.length !== coordinateSpace.rank) return;\n this.value_ = { factors };\n this.curCoordinateSpace = coordinateSpace;\n this.changed.dispatch();\n }\n\n private update() {\n const {\n coordinateSpace: { value: coordinateSpace },\n } = this;\n let value = this.value_;\n const { curCoordinateSpace } = this;\n if (curCoordinateSpace === coordinateSpace) return value;\n const { ids: oldDimensionIds } = curCoordinateSpace;\n const { ids: newDimensionIds, rank } = coordinateSpace;\n const oldFactors = value.factors;\n const newFactors = new Float64Array(rank);\n newFactors.fill(1);\n for (let i = 0; i < rank; ++i) {\n const id = newDimensionIds[i];\n const oldIndex = oldDimensionIds.indexOf(id);\n if (oldIndex === -1) continue;\n newFactors[i] = oldFactors[oldIndex];\n }\n if (arraysEqual(newFactors, oldFactors)) return value;\n value = this.value_ = { factors: newFactors };\n this.curCoordinateSpace = coordinateSpace;\n this.changed.dispatch();\n return value;\n }\n\n assign(other: TrackableRelativeDisplayScales) {\n this.setFactors(other.value.factors);\n }\n}\n\nfunction mapPerDimensionValues<\n T,\n A extends { length: number; [index: number]: T },\n C extends { new (n: number): A },\n>(\n arrayConstructor: C,\n input: A,\n oldCoordinateSpace: CoordinateSpace,\n newCoordinateSpace: CoordinateSpace,\n defaultValue: (index: number) => T,\n): A {\n if (oldCoordinateSpace === newCoordinateSpace) return input;\n const { ids: oldDimensionIds } = oldCoordinateSpace;\n const { rank: newRank, ids: newDimensionIds } = newCoordinateSpace;\n const output = new arrayConstructor(newRank);\n for (let newDim = 0; newDim < newRank; ++newDim) {\n const id = newDimensionIds[newDim];\n const oldDim = oldDimensionIds.indexOf(id);\n output[newDim] = oldDim === -1 ? defaultValue(newDim) : input[oldDim];\n }\n return output;\n}\n\nexport class LinkedRelativeDisplayScales extends LinkedBase {\n value = makeLinked(\n new TrackableRelativeDisplayScales(this.peer.coordinateSpace),\n this.peer,\n this.link,\n {\n assign: (target, source) => target.assign(source),\n difference: (a, b) => {\n const { factors: fa } = a.value;\n const coordinateSpace = a.coordinateSpace.value;\n const fb = b.value.factors;\n return {\n coordinateSpace,\n offsets: vector.subtract(new Float64Array(fa.length), fa, fb),\n };\n },\n add: (\n target,\n source,\n delta: { offsets: Float64Array; coordinateSpace: CoordinateSpace },\n ) => {\n const newOffsets = mapPerDimensionValues(\n Float64Array,\n delta.offsets,\n delta.coordinateSpace,\n target.coordinateSpace.value,\n () => 0,\n );\n target.setFactors(\n vector.add(\n new Float64Array(newOffsets.length),\n newOffsets,\n source.value.factors,\n ),\n );\n },\n subtract: (\n target,\n source,\n delta: { offsets: Float64Array; coordinateSpace: CoordinateSpace },\n ) => {\n const newOffsets = mapPerDimensionValues(\n Float64Array,\n delta.offsets,\n delta.coordinateSpace,\n target.coordinateSpace.value,\n () => 0,\n );\n target.setFactors(\n vector.subtract(\n new Float64Array(newOffsets.length),\n source.value.factors,\n newOffsets,\n ),\n );\n },\n isValid: () => true,\n },\n );\n}\n\nexport interface DisplayDimensionRenderInfo {\n /**\n * Number of global dimensions.\n */\n globalRank: number;\n\n /**\n * Array of length `globalRank` specifying global dimension names.\n */\n globalDimensionNames: readonly string[];\n\n /**\n * Number of displayed dimensions. Must be <= 3.\n */\n displayRank: number;\n\n /**\n * Array of length 3. The first `displayRank` elements specify the indices of the the global\n * dimensions that are displayed. The remaining elements are `-1`.\n */\n displayDimensionIndices: Int32Array;\n\n /**\n * Array of length 3. `voxelPhysicalScales[i]` equals\n * `relativeDisplayScales[d] * coordinateSpace.scales[d]`,\n * where `d = displayDimensionIndices[i]`, or `1` for `i >= rank`.\n */\n voxelPhysicalScales: Float64Array;\n\n /**\n * Unit corresponding to each dimension in `displayDimensionIndices`. `displayDimensionUnits[i]`\n * is equal to `coordinateSpace.units[displayDimensionIndices[i]]`, or `''` if\n * `displayDimensionIndices[i] == -1`.\n */\n displayDimensionUnits: readonly string[];\n\n /**\n * Scale corresponding to each dimension in `displayDimensionIndices`.\n * `displayDimensionScales[i]` is equal to `coordinateSpace.scales[displayDimensionIndices[i]]`,\n * or `1` if `displayDimensionIndices[i] == -1`.\n */\n displayDimensionScales: Float64Array;\n\n /**\n * Physical scale corresponding to the canonical voxel. Equal to minimum of\n * `voxelPhysicalScales.slice(0, rank)`, or `1` if `rank == 0`.\n */\n canonicalVoxelPhysicalSize: number;\n\n /**\n * Array of length 3. Amount by which the voxel coordinates of each display dimensions must be\n * multiplied to convert to canonical voxels. canonicalVoxelFactors[i] = voxelPhysicalScales[d] /\n * canonicalVoxelPhysicalSize, where d = dimensionIndices[i], or `1` for `i >= rank`.\n */\n canonicalVoxelFactors: Float64Array;\n}\n\nfunction getDisplayDimensionRenderInfo(\n coordinateSpace: CoordinateSpace,\n displayDimensions: DisplayDimensions,\n relativeDisplayScales: RelativeDisplayScales,\n): DisplayDimensionRenderInfo {\n const {\n rank: globalRank,\n names: globalDimensionNames,\n units,\n } = coordinateSpace;\n const { displayRank, displayDimensionIndices } = displayDimensions;\n const canonicalVoxelFactors = new Float64Array(3);\n const voxelPhysicalScales = new Float64Array(3);\n let canonicalVoxelPhysicalSize: number;\n const { factors } = relativeDisplayScales;\n const displayDimensionUnits = new Array(3);\n const displayDimensionScales = new Float64Array(3);\n canonicalVoxelFactors.fill(1);\n voxelPhysicalScales.fill(1);\n displayDimensionScales.fill(1);\n displayDimensionUnits.fill(\"\");\n if (displayRank === 0) {\n canonicalVoxelPhysicalSize = 1;\n } else {\n canonicalVoxelPhysicalSize = Number.POSITIVE_INFINITY;\n const { scales } = coordinateSpace;\n for (let i = 0; i < displayRank; ++i) {\n const dim = displayDimensionIndices[i];\n const s = (voxelPhysicalScales[i] = factors[dim] * scales[dim]);\n canonicalVoxelPhysicalSize = Math.min(canonicalVoxelPhysicalSize, s);\n displayDimensionUnits[i] = units[dim];\n displayDimensionScales[i] = scales[dim];\n }\n for (let i = 0; i < displayRank; ++i) {\n canonicalVoxelFactors[i] =\n voxelPhysicalScales[i] / canonicalVoxelPhysicalSize;\n }\n }\n return {\n globalRank,\n globalDimensionNames,\n displayRank,\n displayDimensionIndices,\n displayDimensionUnits,\n displayDimensionScales,\n canonicalVoxelFactors,\n voxelPhysicalScales,\n canonicalVoxelPhysicalSize,\n };\n}\n\nexport function displayDimensionRenderInfosEqual(\n a: DisplayDimensionRenderInfo,\n b: DisplayDimensionRenderInfo,\n) {\n return (\n arraysEqual(a.globalDimensionNames, b.globalDimensionNames) &&\n arraysEqual(a.displayDimensionIndices, b.displayDimensionIndices) &&\n arraysEqual(a.canonicalVoxelFactors, b.canonicalVoxelFactors) &&\n arraysEqual(a.voxelPhysicalScales, b.voxelPhysicalScales) &&\n a.canonicalVoxelPhysicalSize === b.canonicalVoxelPhysicalSize &&\n arraysEqual(a.displayDimensionUnits, b.displayDimensionUnits) &&\n arraysEqual(a.displayDimensionScales, b.displayDimensionScales)\n );\n}\n\nexport function validateDisplayDimensionRenderInfoProperty(\n obj: { displayDimensionRenderInfo: DisplayDimensionRenderInfo },\n expected: DisplayDimensionRenderInfo,\n): boolean {\n const actual = obj.displayDimensionRenderInfo;\n if (actual === expected) return true;\n if (displayDimensionRenderInfosEqual(actual, expected)) {\n obj.displayDimensionRenderInfo = expected;\n return true;\n }\n return false;\n}\n\nexport class WatchableDisplayDimensionRenderInfo extends RefCounted {\n changed = new NullarySignal();\n private curRelativeDisplayScales: RelativeDisplayScales =\n this.relativeDisplayScales.value;\n private curDisplayDimensions: DisplayDimensions =\n this.displayDimensions.value;\n private curCoordinateSpace: CoordinateSpace =\n this.relativeDisplayScales.coordinateSpace.value;\n private value_: DisplayDimensionRenderInfo = getDisplayDimensionRenderInfo(\n this.curCoordinateSpace,\n this.curDisplayDimensions,\n this.curRelativeDisplayScales,\n );\n get value() {\n const {\n relativeDisplayScales: {\n value: relativeDisplayScales,\n coordinateSpace: { value: coordinateSpace },\n },\n displayDimensions: { value: displayDimensions },\n curRelativeDisplayScales,\n curDisplayDimensions,\n curCoordinateSpace,\n } = this;\n let value = this.value_;\n if (\n curRelativeDisplayScales !== relativeDisplayScales ||\n curDisplayDimensions !== displayDimensions ||\n curCoordinateSpace !== coordinateSpace\n ) {\n this.curRelativeDisplayScales = relativeDisplayScales;\n this.curDisplayDimensions = displayDimensions;\n this.curCoordinateSpace = coordinateSpace;\n const newValue = getDisplayDimensionRenderInfo(\n coordinateSpace,\n displayDimensions,\n relativeDisplayScales,\n );\n if (!displayDimensionRenderInfosEqual(value, newValue)) {\n this.value_ = value = newValue;\n this.changed.dispatch();\n }\n }\n return value;\n }\n constructor(\n public relativeDisplayScales: Owned,\n public displayDimensions: Owned,\n ) {\n super();\n this.registerDisposer(relativeDisplayScales);\n this.registerDisposer(displayDimensions);\n const maybeUpdateValue = () => {\n this.value;\n };\n this.registerDisposer(relativeDisplayScales.changed.add(maybeUpdateValue));\n this.registerDisposer(displayDimensions.changed.add(maybeUpdateValue));\n }\n}\n\nexport interface DisplayDimensions {\n coordinateSpace: CoordinateSpace;\n displayRank: number;\n displayDimensionIndices: Int32Array;\n}\n\nexport class TrackableDisplayDimensions\n extends RefCounted\n implements Trackable\n{\n changed = new NullarySignal();\n private default_ = true;\n private value_: DisplayDimensions | undefined = undefined;\n\n constructor(\n public coordinateSpace: WatchableValueInterface,\n ) {\n super();\n this.registerDisposer(\n this.coordinateSpace.changed.add(this.changed.dispatch),\n );\n this.update();\n }\n\n get value() {\n this.update();\n return this.value_!;\n }\n\n private update() {\n const {\n coordinateSpace: { value: coordinateSpace },\n } = this;\n const value = this.value_;\n if (value !== undefined && value.coordinateSpace === coordinateSpace) {\n return;\n }\n if (value === undefined || this.default_) {\n this.setToDefault(coordinateSpace);\n return;\n }\n const newDimensionIndices = new Int32Array(3);\n const { ids: oldDimensionIds } = value.coordinateSpace;\n const { ids: newDimensionIds } = coordinateSpace;\n const oldDimensionIndices = value.displayDimensionIndices;\n const oldRank = value.displayRank;\n let newRank = 0;\n for (let i = 0; i < oldRank; ++i) {\n const newDim = newDimensionIds.indexOf(\n oldDimensionIds[oldDimensionIndices[i]],\n );\n if (newDim === -1) continue;\n newDimensionIndices[newRank] = newDim;\n ++newRank;\n }\n newDimensionIndices.fill(-1, newRank);\n if (newRank === 0) {\n this.default_ = true;\n this.setToDefault(coordinateSpace);\n return;\n }\n this.assignValue(coordinateSpace, newRank, newDimensionIndices);\n this.changed.dispatch();\n }\n\n private setToDefault(coordinateSpace: CoordinateSpace) {\n const displayRank = Math.min(coordinateSpace.rank, 3);\n const displayDimensionIndices = new Int32Array(3);\n displayDimensionIndices.fill(-1);\n for (let i = 0; i < displayRank; ++i) {\n displayDimensionIndices[i] = i;\n }\n this.assignValue(coordinateSpace, displayRank, displayDimensionIndices);\n }\n\n private assignValue(\n coordinateSpace: CoordinateSpace,\n displayRank: number,\n displayDimensionIndices: Int32Array,\n ) {\n this.value_ = {\n coordinateSpace,\n displayRank,\n displayDimensionIndices,\n };\n this.changed.dispatch();\n }\n\n reset() {\n this.default_ = true;\n this.value_ = undefined;\n this.changed.dispatch();\n }\n\n restoreState(obj: any) {\n if (obj === undefined) {\n this.reset();\n return;\n }\n const displayDimensionNames = dimensionNamesFromJson(obj);\n if (displayDimensionNames.length > 3) {\n throw new Error(\"Number of spatial dimensions must be <= 3\");\n }\n const {\n coordinateSpace: { value: coordinateSpace },\n } = this;\n const displayDimensionIndices = new Int32Array(3);\n displayDimensionIndices.fill(-1);\n const { names } = coordinateSpace;\n let displayRank = 0;\n for (const name of displayDimensionNames) {\n const index = names.indexOf(name);\n if (index === -1) continue;\n displayDimensionIndices[displayRank++] = index;\n }\n if (displayRank === 0) {\n this.reset();\n return;\n }\n this.default_ = false;\n this.assignValue(coordinateSpace, displayRank, displayDimensionIndices);\n }\n\n get default() {\n this.update();\n return this.default_;\n }\n\n set default(value: boolean) {\n if (this.default_ === value) return;\n if (value) {\n this.default_ = true;\n this.setToDefault(this.coordinateSpace.value);\n } else {\n this.default_ = false;\n this.changed.dispatch();\n }\n }\n\n setDimensionIndices(rank: number, dimensionIndices: Int32Array) {\n this.default_ = false;\n this.assignValue(this.coordinateSpace.value, rank, dimensionIndices);\n }\n\n toJSON() {\n if (this.default_) return undefined;\n const { value } = this;\n const displayDimensionNames: string[] = [];\n const {\n displayRank,\n displayDimensionIndices,\n coordinateSpace: { names },\n } = value;\n if (displayRank === 0) return undefined;\n for (let i = 0; i < displayRank; ++i) {\n displayDimensionNames[i] = names[displayDimensionIndices[i]];\n }\n return displayDimensionNames;\n }\n\n assign(other: TrackableDisplayDimensions) {\n if (other.default) {\n this.default = true;\n } else {\n const { displayRank, displayDimensionIndices } = other.value;\n this.setDimensionIndices(displayRank, displayDimensionIndices);\n }\n }\n}\n\nexport class LinkedDisplayDimensions extends SimpleLinkedBase {\n value = makeSimpleLinked(\n new TrackableDisplayDimensions(this.peer.coordinateSpace),\n this.peer,\n this.link,\n {\n assign: (target, source) => target.assign(source),\n isValid: () => true,\n },\n );\n}\n\nexport class DisplayPose extends RefCounted {\n changed = new NullarySignal();\n\n get displayDimensions(): Borrowed {\n return this.displayDimensionRenderInfo.displayDimensions;\n }\n\n get relativeDisplayScales(): Borrowed {\n return this.displayDimensionRenderInfo.relativeDisplayScales;\n }\n\n constructor(\n public position: Owned,\n public displayDimensionRenderInfo: WatchableDisplayDimensionRenderInfo,\n public orientation: Owned,\n ) {\n super();\n this.registerDisposer(position);\n this.registerDisposer(orientation);\n this.registerDisposer(displayDimensionRenderInfo);\n this.registerDisposer(position.changed.add(this.changed.dispatch));\n this.registerDisposer(orientation.changed.add(this.changed.dispatch));\n this.registerDisposer(\n displayDimensionRenderInfo.changed.add(this.changed.dispatch),\n );\n }\n\n get valid() {\n return this.position.valid;\n }\n\n /**\n * Resets everything.\n */\n reset() {\n this.position.reset();\n this.orientation.reset();\n this.displayDimensions.reset();\n }\n\n updateDisplayPosition(\n fun: (pos: vec3) => boolean | void,\n temp: vec3 = tempVec3,\n ): boolean {\n const {\n coordinateSpace: { value: coordinateSpace },\n value: voxelCoordinates,\n } = this.position;\n const { displayDimensionIndices, displayRank } =\n this.displayDimensions.value;\n if (coordinateSpace === undefined) return false;\n temp.fill(0);\n for (let i = 0; i < displayRank; ++i) {\n const dim = displayDimensionIndices[i];\n temp[i] = voxelCoordinates[dim];\n }\n if (fun(temp) !== false) {\n for (let i = 0; i < displayRank; ++i) {\n const dim = displayDimensionIndices[i];\n voxelCoordinates[dim] = temp[i];\n }\n this.position.changed.dispatch();\n return true;\n }\n return false;\n }\n\n // Transform from view coordinates to global spatial coordinates.\n toMat4(mat: mat4, zoom: number) {\n mat4.fromQuat(mat, this.orientation.orientation);\n const { value: voxelCoordinates } = this.position;\n const { canonicalVoxelFactors, displayDimensionIndices } =\n this.displayDimensionRenderInfo.value;\n for (let i = 0; i < 3; ++i) {\n const dim = displayDimensionIndices[i];\n const scale = zoom / canonicalVoxelFactors[i];\n mat[i] *= scale;\n mat[4 + i] *= scale;\n mat[8 + i] *= scale;\n mat[12 + i] = voxelCoordinates[dim] || 0;\n }\n }\n\n toMat3(mat: mat3, zoom: number) {\n mat3.fromQuat(mat, this.orientation.orientation);\n const { canonicalVoxelFactors, displayRank } =\n this.displayDimensionRenderInfo.value;\n for (let i = 0; i < displayRank; ++i) {\n const scale = zoom / canonicalVoxelFactors[i];\n mat[i] *= scale;\n mat[3 + i] *= scale;\n mat[6 + i] *= scale;\n }\n }\n\n /**\n * Snaps the orientation to the nearest axis-aligned orientation, and\n * snaps the position to the nearest voxel.\n */\n snap() {\n this.orientation.snap();\n this.position.snapToVoxel();\n this.changed.dispatch();\n }\n\n translateDimensionRelative(dimensionIndex: number, adjustment: number) {\n if (!this.valid) {\n return;\n }\n const { position } = this;\n const { value: voxelCoordinates } = position;\n const { bounds } = position.coordinateSpace.value;\n voxelCoordinates[dimensionIndex] = clampAndRoundCoordinateToVoxelCenter(\n bounds,\n dimensionIndex,\n voxelCoordinates[dimensionIndex] + adjustment,\n );\n position.changed.dispatch();\n }\n\n translateVoxelsRelative(translation: vec3) {\n if (!this.valid) {\n return;\n }\n const temp = vec3.transformQuat(\n tempVec3,\n translation,\n this.orientation.orientation,\n );\n const { position } = this;\n const { value: voxelCoordinates } = position;\n const { displayDimensionIndices, displayRank } =\n this.displayDimensions.value;\n const { bounds } = position.coordinateSpace.value;\n for (let i = 0; i < displayRank; ++i) {\n const dim = displayDimensionIndices[i];\n const adjustment = temp[i];\n if (adjustment === 0) continue;\n voxelCoordinates[dim] = clampAndRoundCoordinateToVoxelCenter(\n bounds,\n dim,\n voxelCoordinates[dim] + adjustment,\n );\n }\n this.position.changed.dispatch();\n }\n\n rotateRelative(axis: vec3, angle: number) {\n const temp = quat.create();\n quat.setAxisAngle(temp, axis, angle);\n const orientation = this.orientation.orientation;\n quat.multiply(orientation, orientation, temp);\n this.orientation.changed.dispatch();\n }\n\n rotateAbsolute(axis: vec3, angle: number, fixedPoint: Float32Array) {\n const {\n coordinateSpace: { value: coordinateSpace },\n value: voxelCoordinates,\n } = this.position;\n if (coordinateSpace === undefined) return;\n const {\n relativeDisplayScales: {\n value: { factors: relativeDisplayScales },\n },\n displayDimensions: {\n value: { displayDimensionIndices, displayRank },\n },\n } = this;\n const { scales } = coordinateSpace;\n const temp = quat.create();\n quat.setAxisAngle(temp, axis, angle);\n const orientation = this.orientation.orientation;\n\n // We want the coordinates in the transformed coordinate frame of the fixed point to remain\n // the same after the rotation.\n\n // We have the invariants:\n // oldOrienation * fixedPointLocal + oldPosition == fixedPoint.\n // newOrientation * fixedPointLocal + newPosition == fixedPoint.\n\n // Therefore, we compute fixedPointLocal by:\n // fixedPointLocal == inverse(oldOrientation) * (fixedPoint - oldPosition).\n const fixedPointLocal = tempVec3;\n tempVec3.fill(0);\n for (let i = 0; i < displayRank; ++i) {\n const dim = displayDimensionIndices[i];\n const diff = fixedPoint[dim] - voxelCoordinates[dim];\n fixedPointLocal[i] = diff * scales[dim] * relativeDisplayScales[dim];\n }\n const invOrientation = quat.invert(tempQuat, orientation);\n vec3.transformQuat(fixedPointLocal, fixedPointLocal, invOrientation);\n\n // We then compute the newPosition by:\n // newPosition := fixedPoint - newOrientation * fixedPointLocal.\n quat.multiply(orientation, temp, orientation);\n vec3.transformQuat(fixedPointLocal, fixedPointLocal, orientation);\n\n for (let i = 0; i < displayRank; ++i) {\n const dim = displayDimensionIndices[i];\n voxelCoordinates[dim] =\n fixedPoint[dim] -\n fixedPointLocal[i] / (scales[dim] * relativeDisplayScales[dim]);\n }\n this.position.changed.dispatch();\n this.orientation.changed.dispatch();\n }\n\n translateNonDisplayDimension(\n nonSpatialDimensionIndex: number,\n adjustment: number,\n ) {\n if (!this.valid) return;\n const { displayDimensionIndices } = this.displayDimensions.value;\n const { position } = this;\n const rank = position.coordinateSpace.value.rank;\n for (let i = 0; i < rank; ++i) {\n if (displayDimensionIndices.indexOf(i) !== -1) continue;\n if (nonSpatialDimensionIndex-- === 0) {\n this.translateDimensionRelative(i, adjustment);\n return;\n }\n }\n }\n}\n\nexport type TrackableZoomInterface =\n | TrackableProjectionZoom\n | TrackableCrossSectionZoom;\n\nexport class LinkedZoomState<\n T extends TrackableProjectionZoom | TrackableCrossSectionZoom,\n> extends LinkedBase {\n constructor(\n peer: Owned,\n displayDimensionRenderInfo: Owned,\n ) {\n super(peer);\n this.value = (() => {\n const self: T = new (peer.constructor as any)(displayDimensionRenderInfo);\n const assign = (target: T, source: T) => {\n target.assign(source);\n };\n const difference = (a: T, b: T) => {\n return (\n (a.value / b.value) *\n (a.canonicalVoxelPhysicalSize / b.canonicalVoxelPhysicalSize)\n );\n };\n const add = (target: T, source: T, amount: number) => {\n target.setPhysicalScale(\n source.value * amount,\n source.canonicalVoxelPhysicalSize,\n );\n };\n const subtract = (target: T, source: T, amount: number) => {\n target.setPhysicalScale(\n source.value / amount,\n source.canonicalVoxelPhysicalSize,\n );\n };\n const isValid = (x: T) =>\n x.coordinateSpaceValue.valid && x.canonicalVoxelPhysicalSize !== 0;\n makeLinked(\n self as RefCounted & { changed: NullarySignal },\n this.peer,\n this.link,\n {\n assign,\n isValid,\n difference,\n add,\n subtract,\n },\n );\n return self;\n })();\n }\n}\n\nexport function linkedStateLegacyJsonView<\n T extends LinkableState & { readonly legacyJsonView: Trackable },\n>(linked: LinkedBase) {\n return {\n changed: linked.changed,\n toJSON() {\n return linked.toJSON();\n },\n restoreState(obj: unknown) {\n restoreLinkedFromJson(linked.link, linked.value.legacyJsonView, obj);\n },\n reset() {\n linked.reset();\n },\n };\n}\n\nabstract class TrackableZoom\n extends RefCounted\n implements Trackable, WatchableValueInterface\n{\n readonly changed = new NullarySignal();\n private curCanonicalVoxelPhysicalSize = 0;\n private value_: number = Number.NaN;\n protected legacyValue_: number = Number.NaN;\n\n /**\n * Zoom factor. For cross section views, in canonical voxels per viewport pixel. For projection\n * views, in canonical voxels per viewport height (for orthographic projection).\n */\n get value() {\n this.handleCoordinateSpaceChanged();\n return this.value_;\n }\n\n set value(value: number) {\n const { canonicalVoxelPhysicalSize } = this;\n if (\n Object.is(value, this.value_) &&\n canonicalVoxelPhysicalSize === this.curCanonicalVoxelPhysicalSize\n ) {\n return;\n }\n this.curCanonicalVoxelPhysicalSize = canonicalVoxelPhysicalSize;\n this.legacyValue_ = Number.NaN;\n this.value_ = value;\n this.changed.dispatch();\n }\n\n get canonicalVoxelPhysicalSize() {\n return this.displayDimensionRenderInfo.value.canonicalVoxelPhysicalSize;\n }\n\n get coordinateSpaceValue() {\n return this.displayDimensionRenderInfo.relativeDisplayScales.coordinateSpace\n .value;\n }\n\n /**\n * Sets the zoom factor in the legacy units. For cross section views, `1e-9` spatial units per\n * viewport pixel. For projection views, `2 * 100 * Math.tan(Math.PI / 8) * 1e-9` spatial units\n * per viewport height (for orthographic projection).\n */\n set legacyValue(value: number) {\n if (Object.is(value, this.legacyValue_)) return;\n this.value_ = Number.NaN;\n this.legacyValue_ = value;\n this.curCanonicalVoxelPhysicalSize = 0;\n this.changed.dispatch();\n }\n\n get legacyValue() {\n return this.legacyValue_;\n }\n\n constructor(\n public displayDimensionRenderInfo: Owned,\n ) {\n super();\n this.registerDisposer(displayDimensionRenderInfo);\n this.registerDisposer(\n displayDimensionRenderInfo.changed.add(() =>\n this.handleCoordinateSpaceChanged(),\n ),\n );\n this.registerDisposer(\n displayDimensionRenderInfo.relativeDisplayScales.coordinateSpace.changed.add(\n () => this.handleCoordinateSpaceChanged(),\n ),\n );\n this.handleCoordinateSpaceChanged();\n }\n\n handleCoordinateSpaceChanged() {\n const { value_ } = this;\n const {\n displayDimensionRenderInfo: {\n value: { canonicalVoxelPhysicalSize },\n relativeDisplayScales: {\n coordinateSpace: { value: coordinateSpace },\n },\n },\n } = this;\n const { curCanonicalVoxelPhysicalSize } = this;\n if (\n !Number.isNaN(value_) &&\n canonicalVoxelPhysicalSize === curCanonicalVoxelPhysicalSize\n ) {\n return;\n }\n if (!Number.isNaN(value_)) {\n if (curCanonicalVoxelPhysicalSize !== 0) {\n this.value_ =\n value_ * (curCanonicalVoxelPhysicalSize / canonicalVoxelPhysicalSize);\n this.curCanonicalVoxelPhysicalSize = canonicalVoxelPhysicalSize;\n this.changed.dispatch();\n }\n return;\n }\n if (!coordinateSpace.valid || canonicalVoxelPhysicalSize === 0) {\n return;\n }\n this.curCanonicalVoxelPhysicalSize = canonicalVoxelPhysicalSize;\n this.value_ = this.getDefaultValue();\n this.changed.dispatch();\n }\n\n protected abstract getDefaultValue(): number;\n\n toJSON() {\n const { value } = this;\n return Number.isNaN(value) ? undefined : value;\n }\n\n restoreState(obj: any) {\n this.curCanonicalVoxelPhysicalSize = 0;\n this.legacyValue_ = Number.NaN;\n if (obj === undefined) {\n this.value_ = Number.NaN;\n } else {\n this.value_ = verifyFinitePositiveFloat(obj);\n }\n this.changed.dispatch();\n }\n\n reset() {\n this.curCanonicalVoxelPhysicalSize = 0;\n this.value_ = Number.NaN;\n this.legacyValue_ = Number.NaN;\n this.changed.dispatch();\n }\n\n get legacyJsonView() {\n const self = this;\n return {\n changed: self.changed,\n toJSON() {\n return self.toJSON();\n },\n reset() {\n return self.reset();\n },\n restoreState(obj: any) {\n self.legacyValue = verifyFinitePositiveFloat(obj);\n },\n };\n }\n\n setPhysicalScale(\n scaleInCanonicalVoxels: number,\n canonicalVoxelPhysicalSize: number,\n ) {\n const curCanonicalVoxelPhysicalSize = (this.curCanonicalVoxelPhysicalSize =\n this.canonicalVoxelPhysicalSize);\n this.value =\n scaleInCanonicalVoxels *\n (canonicalVoxelPhysicalSize / curCanonicalVoxelPhysicalSize);\n }\n\n assign(source: TrackableZoomInterface) {\n const { legacyValue } = source;\n if (!Number.isNaN(legacyValue)) {\n this.legacyValue = legacyValue;\n } else {\n this.setPhysicalScale(source.value, source.canonicalVoxelPhysicalSize);\n }\n }\n}\n\nexport class TrackableCrossSectionZoom extends TrackableZoom {\n protected getDefaultValue() {\n const { legacyValue_ } = this;\n if (Number.isNaN(legacyValue_)) {\n // Default is 1 voxel per viewport pixel.\n return 1;\n }\n const { canonicalVoxelPhysicalSize } = this;\n return (this.legacyValue_ * 1e-9) / canonicalVoxelPhysicalSize;\n }\n}\n\nexport class TrackableProjectionZoom extends TrackableZoom {\n protected getDefaultValue() {\n const { legacyValue_ } = this;\n if (!Number.isNaN(legacyValue_)) {\n this.legacyValue_ = Number.NaN;\n const { canonicalVoxelPhysicalSize } = this;\n return (\n (2 * 100 * Math.tan(Math.PI / 8) * 1e-9 * legacyValue_) /\n canonicalVoxelPhysicalSize\n );\n }\n const {\n coordinateSpaceValue: {\n bounds: { lowerBounds, upperBounds },\n },\n } = this;\n const { canonicalVoxelFactors, displayDimensionIndices } =\n this.displayDimensionRenderInfo.value;\n let value = canonicalVoxelFactors.reduce((x, factor, i) => {\n const dim = displayDimensionIndices[i];\n const extent = (upperBounds[dim] - lowerBounds[dim]) * factor;\n return Math.max(x, extent);\n }, 0);\n if (!Number.isFinite(value)) {\n // Default to showing 1024 voxels if there is no bounds information.\n value = 1024;\n } else {\n value = 2 ** Math.ceil(Math.log2(value));\n }\n return value;\n }\n}\n\nexport class TrackableDepthRange\n extends RefCounted\n implements WatchableValueInterface\n{\n changed = new NullarySignal();\n\n constructor(\n public readonly defaultValue: number,\n public displayDimensionRenderInfo: WatchableValueInterface,\n ) {\n super();\n this.value_ = defaultValue;\n this.canonicalVoxelPhysicalSize =\n displayDimensionRenderInfo.value.canonicalVoxelPhysicalSize;\n this.registerDisposer(\n displayDimensionRenderInfo.changed.add(() => {\n this.value;\n }),\n );\n }\n\n private value_: number;\n canonicalVoxelPhysicalSize: number;\n\n get value() {\n let { value_ } = this;\n if (value_ > 0) {\n const { canonicalVoxelPhysicalSize } =\n this.displayDimensionRenderInfo.value;\n const prevCanonicalVoxelPhysicalSize = this.canonicalVoxelPhysicalSize;\n if (canonicalVoxelPhysicalSize !== prevCanonicalVoxelPhysicalSize) {\n this.canonicalVoxelPhysicalSize = canonicalVoxelPhysicalSize;\n value_ =\n this.value_ =\n value_ =\n prevCanonicalVoxelPhysicalSize / canonicalVoxelPhysicalSize;\n this.changed.dispatch();\n }\n }\n return value_;\n }\n\n set value(value: number) {\n if (value === this.value) return;\n this.value_ = value;\n const { canonicalVoxelPhysicalSize } =\n this.displayDimensionRenderInfo.value;\n this.canonicalVoxelPhysicalSize = canonicalVoxelPhysicalSize;\n this.changed.dispatch();\n }\n\n toJSON() {\n const { value } = this;\n if (value === this.defaultValue) return undefined;\n return value;\n }\n\n reset() {\n this.value = this.defaultValue;\n }\n\n restoreState(obj: unknown) {\n if (typeof obj !== \"number\" || !Number.isFinite(obj) || obj === 0) {\n this.value = this.defaultValue;\n } else {\n this.value = obj;\n }\n }\n\n setValueAbsolute(value: number, sourceCanonicalVoxelPhysicalSize: number) {\n if (value > 0) {\n const { canonicalVoxelPhysicalSize } =\n this.displayDimensionRenderInfo.value;\n value =\n value * (sourceCanonicalVoxelPhysicalSize / canonicalVoxelPhysicalSize);\n }\n this.value = value;\n }\n\n assign(other: TrackableDepthRange) {\n this.setValueAbsolute(other.value, other.canonicalVoxelPhysicalSize);\n }\n}\n\nexport class LinkedDepthRange extends SimpleLinkedBase {\n constructor(\n peer: Owned,\n displayDimensionRenderInfo: WatchableValueInterface,\n ) {\n super(peer);\n this.value = makeSimpleLinked(\n new TrackableDepthRange(peer.defaultValue, displayDimensionRenderInfo),\n this.peer,\n this.link,\n {\n assign: (target, source) => target.assign(source),\n isValid: () => true,\n },\n );\n }\n}\n\nexport class NavigationState<\n Zoom extends TrackableZoomInterface = TrackableZoomInterface,\n> extends RefCounted {\n changed = new NullarySignal();\n\n constructor(\n public pose: Owned,\n public zoomFactor: Owned,\n public depthRange: Owned,\n ) {\n super();\n this.registerDisposer(pose);\n this.registerDisposer(zoomFactor);\n this.registerDisposer(depthRange);\n this.registerDisposer(this.pose.changed.add(this.changed.dispatch));\n this.registerDisposer(this.zoomFactor.changed.add(this.changed.dispatch));\n this.registerDisposer(this.depthRange.changed.add(this.changed.dispatch));\n }\n get coordinateSpace() {\n return this.pose.position.coordinateSpace;\n }\n\n /**\n * Resets everything.\n */\n reset() {\n this.pose.reset();\n this.zoomFactor.reset();\n }\n\n get position() {\n return this.pose.position;\n }\n get displayDimensions() {\n return this.pose.displayDimensions;\n }\n get relativeDisplayScales() {\n return this.pose.relativeDisplayScales;\n }\n get displayDimensionRenderInfo() {\n return this.pose.displayDimensionRenderInfo;\n }\n toMat4(mat: mat4) {\n this.pose.toMat4(mat, this.zoomFactor.value);\n }\n toMat3(mat: mat3) {\n this.pose.toMat3(mat, this.zoomFactor.value);\n }\n\n get relativeDepthRange() {\n let depthRange = this.depthRange.value;\n if (depthRange > 0) {\n depthRange /= this.zoomFactor.value;\n } else {\n depthRange *= -1;\n }\n return depthRange;\n }\n\n get valid() {\n return this.pose.valid && !Number.isNaN(this.zoomFactor.value);\n }\n\n zoomBy(factor: number) {\n this.zoomFactor.value *= factor;\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Hierarchical mapping from keys to values.\n */\n\nexport interface HierarchicalMapInterface {\n get(key: Key): Value | undefined;\n entries(): IterableIterator<[Key, Value]>;\n}\n\n/**\n * Maps string event identifiers to string action identifiers.\n *\n * When an event identifier is looked up in a given HierarchicalMap, it is resolved to a\n * corresponding action identifier in one of two ways:\n *\n * 1. via mappings defined directly on the HierarchicalMap.\n *\n * 2. via a recursive lookup on a \"parent\" HierarchicalMap that has been specified for the root\n * HierarchicalMap on which the lookup was initiated.\n *\n * HierarchicalMap objects may be specified as \"parents\" of another HierarchicalMap along with a\n * specified numerical priority value, such that there is a directed graph of HierarchicalMap\n * objects. Cycles in this graph may lead to infinite looping.\n *\n * Recursive lookups in parent HierarchicalMap objects are performed in order of decreasing\n * priority. The lookup stops as soon as a mapping is found. Direct bindings have a priority of 0.\n * Therefore, parent maps with a priority higher than 0 take precedence over direct bindings.\n */\nexport class HierarchicalMap<\n Key,\n Value,\n Parent extends HierarchicalMapInterface<\n Key,\n Value\n > = HierarchicalMapInterface,\n> implements HierarchicalMapInterface\n{\n parents = new Array();\n private parentPriorities = new Array();\n bindings = new Map();\n\n /**\n * If an existing HierarchicalMap is specified, a shallow copy is made.\n *\n * @param existing Existing map to make a shallow copy of.\n */\n constructor(existing?: HierarchicalMap) {\n if (existing !== undefined) {\n this.parents.push(...existing.parents);\n this.parentPriorities.push(...existing.parentPriorities);\n for (const [k, v] of existing.bindings) {\n this.bindings.set(k, v);\n }\n }\n }\n\n /**\n * Register `parent` as a parent map. If `priority > 0`, this map will take precedence over\n * direct bindings.\n *\n * @returns A nullary function that unregisters the parent (and may be called at most once).\n */\n addParent(parent: Parent, priority: number) {\n const { parents, parentPriorities } = this;\n let index = 0;\n const { length } = parents;\n while (index < length && priority < parentPriorities[index]) {\n ++index;\n }\n parents.splice(index, 0, parent);\n parentPriorities.splice(index, 0, priority);\n\n return () => {\n this.removeParent(parent);\n };\n }\n\n /**\n * Unregisters `parent` as a parent.\n */\n removeParent(parent: Parent) {\n const index = this.parents.indexOf(parent);\n if (index === -1) {\n throw new Error(\"Attempt to remove non-existent parent map.\");\n }\n this.parents.splice(index, 1);\n this.parentPriorities.splice(index, 1);\n }\n\n /**\n * Register a direct binding.\n */\n set(key: Key, value: Value) {\n this.bindings.set(key, value);\n }\n\n /**\n * Unregister a direct binding.\n */\n delete(key: Key) {\n this.bindings.delete(key);\n }\n\n /**\n * Deletes all bindings, including parents.\n */\n clear() {\n this.bindings.clear();\n this.parents.length = 0;\n this.parentPriorities.length = 0;\n }\n\n /**\n * Lookup the highest priority value to which the specified key is mapped.\n */\n get(key: Key): Value | undefined {\n const { parents, parentPriorities } = this;\n const numParents = parentPriorities.length;\n let parentIndex = 0;\n let value;\n for (\n ;\n parentIndex < numParents && parentPriorities[parentIndex] > 0;\n ++parentIndex\n ) {\n value = parents[parentIndex].get(key);\n if (value !== undefined) {\n return value;\n }\n }\n value = this.bindings.get(key);\n if (value !== undefined) {\n return value;\n }\n for (; parentIndex < numParents; ++parentIndex) {\n value = parents[parentIndex].get(key);\n if (value !== undefined) {\n return value;\n }\n }\n return undefined;\n }\n\n /**\n * Find all values to which the specified key is mapped.\n */\n *getAll(key: Key): IterableIterator {\n const { parents, parentPriorities } = this;\n const numParents = parentPriorities.length;\n const parentIndex = 0;\n let value;\n while (parentIndex < numParents && parentPriorities[parentIndex] > 0) {\n value = parents[parentIndex].get(key);\n if (value !== undefined) {\n yield value;\n }\n }\n value = this.bindings.get(key);\n if (value !== undefined) {\n yield value;\n }\n while (parentIndex < numParents) {\n value = parents[parentIndex].get(key);\n if (value !== undefined) {\n yield value;\n }\n }\n }\n\n *entries(): IterableIterator<[Key, Value]> {\n const { parents, parentPriorities } = this;\n const numParents = parentPriorities.length;\n let parentIndex = 0;\n for (\n ;\n parentIndex < numParents && parentPriorities[parentIndex] > 0;\n ++parentIndex\n ) {\n yield* parents[parentIndex].entries();\n }\n yield* this.bindings.entries();\n for (; parentIndex < numParents; ++parentIndex) {\n yield* parents[parentIndex].entries();\n }\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { registerEventListener } from \"#src/util/disposable.js\";\nimport type { HierarchicalMapInterface } from \"#src/util/hierarchical_map.js\";\nimport { HierarchicalMap } from \"#src/util/hierarchical_map.js\";\n\n/**\n * @file Facilities for dispatching user-defined actions in response to input events.\n */\n\n/**\n * Specifies a unique string representation of an input event, used for matching an input event to a\n * corresponding action with which it has been associated.\n *\n * The EventIdentifier combines several pieces of information using the following syntax:\n *\n * NormalizedEventIdentifier ::= phase ':' ( modifier '+' )* base-event-identifier\n *\n * - The event `phase` name, corresponding to the phase of DOM event processing at which the event was\n * received, which may be 'at', 'bubble', or 'capture'. (Currently, 'capture' is not supported.)\n *\n * - The set of `modifier` keys ('control', 'alt', 'meta', and/or 'shift') active when the event occurred.\n *\n * - The `base-event-identifier`, which in the case of keyboard events is the lowercase KeyboardEvent\n * `code`, and in the case of mouse events is one of:\n *\n * - 'mousedown' + n\n * - 'mouseup' + n\n * - 'click' + n\n * - 'dblclick' + n\n * - 'wheel'\n *\n * where `n` is the index of the mouse button, starting from 0.\n *\n * In the normalized form used for matching events, the set of modifiers must be specified in\n * exactly the order: 'control', 'alt', 'meta', 'shift'. Consequently, there is exactly one\n * NormalizedEventIdentifier representation for a given input event.\n */\nexport type NormalizedEventIdentifier = string;\n\n/**\n * An EventIdentifier specifies a criteria for matching input events using a relaxed form of the\n * NormalizedEventIdentifier syntax. Each EventIdentifier corresponds to one or more\n * NormalizedEventIdentifier values.\n *\n * EventIdentifier ::= [ phase ':' ] ( modifier '+' )* base-event-identifier\n *\n * In addition to the phase being optional, the modifiers may be specified in any order. If the\n * phase is not specified, then the EventIdentifier matches both the 'at' and 'bubble' phases.\n */\nexport type EventIdentifier = string;\n\n/**\n * Identifies a user-defined action name. Actions are dispatched as DOM events, using 'action:'\n * prepended to the ActionIdentifier as the event type.\n */\nexport type ActionIdentifier = string;\n\n/**\n * Specifies how to handle an event.\n */\nexport interface EventAction {\n /**\n * Identifier of action to dispatch.\n */\n action: ActionIdentifier;\n\n /**\n * Whether to call `stopPropagation()` on the triggering event. Defaults to true.\n */\n stopPropagation?: boolean;\n\n /**\n * Whether to call `preventDefault()` on the triggering event. Defaults to true. Additionally,\n * if `preventDefault()` is called on the dispatched ActionEvent, `preventDefault()` will also be\n * called on the triggering event regardless of the value of `preventDefault`.\n */\n preventDefault?: boolean;\n\n originalEventIdentifier?: string;\n}\n\nexport type EventActionMapInterface = HierarchicalMapInterface<\n NormalizedEventIdentifier,\n EventAction\n>;\n\nexport enum Modifiers {\n CONTROL = 1,\n ALT = 2,\n META = 4,\n SHIFT = 8,\n}\n\nexport type ModifierMask = number;\n\nexport interface EventModifierKeyState {\n ctrlKey: boolean;\n altKey: boolean;\n metaKey: boolean;\n shiftKey: boolean;\n}\n\nexport function getEventModifierMask(\n event: EventModifierKeyState,\n): ModifierMask {\n return (\n (event.ctrlKey ? Modifiers.CONTROL : 0) |\n (event.altKey ? Modifiers.ALT : 0) |\n (event.metaKey ? Modifiers.META : 0) |\n (event.shiftKey ? Modifiers.SHIFT : 0)\n );\n}\n\nexport function getStrokeIdentifier(keyName: string, modifiers: ModifierMask) {\n let identifier = \"\";\n if (modifiers & Modifiers.CONTROL) {\n identifier += \"control+\";\n }\n if (modifiers & Modifiers.ALT) {\n identifier += \"alt+\";\n }\n if (modifiers & Modifiers.META) {\n identifier += \"meta+\";\n }\n if (modifiers & Modifiers.SHIFT) {\n identifier += \"shift+\";\n }\n identifier += keyName;\n return identifier;\n}\n\nfunction getStrokeIdentifierWithOptionalModifiers(\n keyName: string,\n modifiers: ModifierMask,\n optionalModifiers: ModifierMask,\n) {\n let identifier = \"\";\n if (modifiers & Modifiers.CONTROL) {\n identifier += \"control+\";\n }\n if (optionalModifiers & Modifiers.CONTROL) {\n identifier += \"control?+\";\n }\n if (modifiers & Modifiers.ALT) {\n identifier += \"alt+\";\n }\n if (optionalModifiers & Modifiers.ALT) {\n identifier += \"alt?+\";\n }\n if (modifiers & Modifiers.META) {\n identifier += \"meta+\";\n }\n if (optionalModifiers & Modifiers.META) {\n identifier += \"meta?+\";\n }\n if (modifiers & Modifiers.SHIFT) {\n identifier += \"shift+\";\n }\n if (optionalModifiers & Modifiers.SHIFT) {\n identifier += \"shift?+\";\n }\n identifier += keyName;\n return identifier;\n}\n\ninterface ParsedEventIdentifier {\n phase: undefined | \"at\" | \"bubble\";\n keyName: string;\n modifiers: ModifierMask;\n optionalModifiers: ModifierMask;\n}\n\nfunction parseEventIdentifier(identifier: string): ParsedEventIdentifier {\n const firstColonOffset = identifier.indexOf(\":\");\n let phase: string | undefined;\n if (firstColonOffset !== -1) {\n phase = identifier.substring(0, firstColonOffset);\n // TODO(jbms): Support capture phase.\n if (phase !== \"at\" && phase !== \"bubble\") {\n throw new Error(`Invalid event phase: ${JSON.stringify(phase)}`);\n }\n }\n const parts = identifier.substring(firstColonOffset + 1).split(\"+\");\n let keyName: string | undefined;\n let modifiers = 0;\n let optionalModifiers = 0;\n loop: for (const part of parts) {\n switch (part) {\n case \"control\":\n modifiers |= Modifiers.CONTROL;\n break;\n case \"control?\":\n optionalModifiers |= Modifiers.CONTROL;\n break;\n case \"alt\":\n modifiers |= Modifiers.ALT;\n break;\n case \"alt?\":\n optionalModifiers |= Modifiers.ALT;\n break;\n case \"meta\":\n modifiers |= Modifiers.META;\n break;\n case \"meta?\":\n optionalModifiers |= Modifiers.META;\n break;\n case \"shift\":\n modifiers |= Modifiers.SHIFT;\n break;\n case \"shift?\":\n optionalModifiers |= Modifiers.SHIFT;\n break;\n default:\n if (keyName === undefined) {\n keyName = part;\n } else {\n keyName = undefined;\n break loop;\n }\n }\n }\n if (keyName === undefined || modifiers & optionalModifiers) {\n throw new Error(`Invalid event identifier: ${JSON.stringify(identifier)}`);\n }\n return {\n phase: phase as ParsedEventIdentifier[\"phase\"],\n keyName,\n modifiers,\n optionalModifiers,\n };\n}\n\nfunction* getNormalizedStrokeIdentifiers(\n keyName: string,\n modifiers: ModifierMask,\n optionalModifiers: ModifierMask,\n): Iterable {\n if (optionalModifiers === 0) {\n yield getStrokeIdentifier(keyName, modifiers);\n }\n for (let m = 0; m < 16; ++m) {\n if ((m & (modifiers | optionalModifiers)) !== m) continue;\n if ((m & modifiers) !== modifiers) continue;\n yield getStrokeIdentifier(keyName, m);\n }\n}\n\n/**\n * Normalizes a user-specified EventIdentifier into a list of one or more corresponding\n * NormalizedEventIdentifier strings.\n */\nfunction* getNormalizedEventIdentifiers(\n parsed: ParsedEventIdentifier,\n): Iterable {\n const { phase } = parsed;\n const strokeIdentifiers = getNormalizedStrokeIdentifiers(\n parsed.keyName,\n parsed.modifiers,\n parsed.optionalModifiers,\n );\n if (phase === undefined) {\n for (const suffix of strokeIdentifiers) {\n yield `at:${suffix}`;\n yield `bubble:${suffix}`;\n }\n } else {\n for (const suffix of strokeIdentifiers) {\n yield `${phase}:${suffix}`;\n }\n }\n}\n\n/**\n * Specifies either an EventAction or a bare ActionIdentifier.\n */\ntype ActionOrEventAction = EventAction | ActionIdentifier;\n\n/**\n * Normalizes an ActionOrEventAction into an EventAction.\n */\nexport function normalizeEventAction(\n parsed: ParsedEventIdentifier,\n action: ActionOrEventAction,\n): EventAction {\n const identifier = getStrokeIdentifierWithOptionalModifiers(\n parsed.keyName,\n parsed.modifiers,\n parsed.optionalModifiers,\n );\n if (typeof action === \"string\") {\n return { action: action, originalEventIdentifier: identifier };\n }\n return { ...action, originalEventIdentifier: identifier };\n}\n\n// Strips the phase and optional modifiers.\nfunction friendlyEventIdentifier(identifier: string): string {\n identifier = identifier.replace(\n /^(?:at|bubble|capture)|(?:(?:shift|control|alt|meta)\\?\\+)/g,\n \"\",\n );\n return identifier;\n}\n\n/**\n * Hierarchical map of `EventIdentifier` specifications to `EventAction` specifications. These maps\n * are used by KeyboardEventBinder and MouseEventBinder to dispatch an ActionEvent in response to an\n * input event.\n */\nexport class EventActionMap\n extends HierarchicalMap<\n NormalizedEventIdentifier,\n EventAction,\n EventActionMap\n >\n implements EventActionMapInterface\n{\n label: string | undefined;\n\n /**\n * Returns a new EventActionMap with the specified bindings.\n *\n * The keys of the `bindings` object specify unnormalized event identifiers to be mapped to their\n * corresponding `ActionOrEventAction` values.\n */\n static fromObject(\n bindings: { [key: string]: ActionOrEventAction },\n options: {\n label?: string;\n parents?: Iterable<[EventActionMap, number]>;\n } = {},\n ) {\n const map = new EventActionMap();\n map.label = options.label;\n if (options.parents !== undefined) {\n for (const [parent, priority] of options.parents) {\n map.addParent(parent, priority);\n }\n }\n for (const key of Object.keys(bindings)) {\n map.set(key, bindings[key]);\n }\n return map;\n }\n\n setFromObject(bindings: { [key: string]: ActionOrEventAction }) {\n for (const key of Object.keys(bindings)) {\n this.set(key, bindings[key]);\n }\n }\n\n /**\n * Maps the specified event `identifier` to the specified `action`.\n *\n * The `identifier` may be unnormalized; the actual mapping is created for each corresponding\n * normalized identifier.\n */\n set(identifier: EventIdentifier, action: ActionOrEventAction) {\n const parsedIdentifier = parseEventIdentifier(identifier);\n const normalizedAction = normalizeEventAction(parsedIdentifier, action);\n for (const normalizedIdentifier of getNormalizedEventIdentifiers(\n parsedIdentifier,\n )) {\n super.set(normalizedIdentifier, normalizedAction);\n }\n }\n\n /**\n * Deletes the mapping for the specified `identifier`.\n *\n * The `identifier` may be unnormalized; the mapping is deleted for each corresponding normalized\n * identifier.\n */\n delete(identifier: EventIdentifier) {\n for (const normalizedIdentifier of getNormalizedEventIdentifiers(\n parseEventIdentifier(identifier),\n )) {\n super.delete(normalizedIdentifier);\n }\n }\n\n describe(): string {\n const bindings = [];\n const uniqueBindings = new Map();\n for (const [, value] of this.entries()) {\n uniqueBindings.set(value.originalEventIdentifier!, value.action);\n }\n const actionBindings = new Map();\n for (const [eventIdentifier, action] of uniqueBindings) {\n let events = actionBindings.get(action);\n if (events === undefined) {\n events = [];\n actionBindings.set(action, events);\n }\n events.push(friendlyEventIdentifier(eventIdentifier));\n }\n for (const [action, events] of actionBindings) {\n const eventStr =\n events.length === 1 ? events[0] : `{${events.join(\",\")}}`;\n bindings.push(`${eventStr}→${action}`);\n }\n return bindings.join(\", \");\n }\n}\n\nexport function dispatchEventAction(\n originalEvent: Event,\n detail: any,\n eventAction: EventAction | undefined,\n) {\n if (eventAction === undefined) {\n return;\n }\n if (eventAction.stopPropagation !== false) {\n originalEvent.stopPropagation();\n }\n const actionEvent = new CustomEvent(\"action:\" + eventAction.action, {\n bubbles: true,\n detail: detail,\n cancelable: true,\n });\n const cancelled = !originalEvent.target!.dispatchEvent(actionEvent);\n if (eventAction.preventDefault !== false || cancelled) {\n originalEvent.preventDefault();\n }\n}\n\nexport const eventPhaseNames: string[] = [];\neventPhaseNames[Event.AT_TARGET] = \"at\";\neventPhaseNames[Event.CAPTURING_PHASE] = \"capture\";\neventPhaseNames[Event.BUBBLING_PHASE] = \"bubble\";\n\nexport function dispatchEvent(\n baseIdentifier: EventIdentifier,\n originalEvent: Event,\n eventPhase: number,\n detail: any,\n eventMap: EventActionMapInterface,\n) {\n const eventIdentifier = eventPhaseNames[eventPhase] + \":\" + baseIdentifier;\n const eventAction = eventMap.get(eventIdentifier);\n dispatchEventAction(originalEvent, detail, eventAction);\n}\n\nexport function dispatchEventWithModifiers(\n baseIdentifier: EventIdentifier,\n originalEvent: Event & EventModifierKeyState,\n detail: any,\n eventMap: EventActionMapInterface,\n) {\n dispatchEvent(\n getStrokeIdentifier(baseIdentifier, getEventModifierMask(originalEvent)),\n originalEvent,\n originalEvent.eventPhase,\n detail,\n eventMap,\n );\n}\n\n/**\n * DOM Event type used for dispatching actions.\n *\n * Additional information relevant to the acction is specified as the `detail` property.\n */\nexport interface ActionEvent extends CustomEvent {\n detail: Info;\n}\n\n/**\n * Register an event listener for the specified `action`.\n *\n * There is no checking that the `TriggerEvent` type is suitable for use with the specified\n * `action`.\n *\n * @returns A nullary disposer function that unregisters the listener when called.\n */\nexport function registerActionListener(\n target: EventTarget,\n action: ActionIdentifier,\n listener: (event: ActionEvent) => void,\n options?: boolean | AddEventListenerOptions,\n) {\n return registerEventListener(target, `action:${action}`, listener, options);\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Facility for triggering named actions in response to mouse events.\n */\n\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type {\n ActionEvent,\n EventActionMapInterface,\n} from \"#src/util/event_action_map.js\";\nimport {\n dispatchEventWithModifiers,\n EventActionMap,\n registerActionListener,\n} from \"#src/util/event_action_map.js\";\n\nexport class MouseEventBinder<\n EventMap extends EventActionMapInterface,\n> extends RefCounted {\n private dispatch(baseIdentifier: string, event: MouseEvent) {\n if (this.shouldIgnore?.(event)) return;\n dispatchEventWithModifiers(baseIdentifier, event, event, this.eventMap);\n }\n shouldIgnore: ((event: MouseEvent) => boolean) | undefined = undefined;\n constructor(\n public target: EventTarget,\n public eventMap: EventMap,\n commonHandler?: (event: MouseEvent) => void,\n ) {\n super();\n this.registerEventListener(target, \"wheel\", (event: WheelEvent) => {\n if (commonHandler !== undefined) commonHandler(event);\n this.dispatch(\"wheel\", event);\n });\n this.registerEventListener(target, \"click\", (event: MouseEvent) => {\n if (commonHandler !== undefined) commonHandler(event);\n this.dispatch(`click${event.button}`, event);\n });\n this.registerEventListener(target, \"dblclick\", (event: MouseEvent) => {\n if (commonHandler !== undefined) commonHandler(event);\n this.dispatch(`dblclick${event.button}`, event);\n });\n this.registerEventListener(target, \"mousedown\", (event: MouseEvent) => {\n if (commonHandler !== undefined) commonHandler(event);\n let button = event.button;\n // Under Firefox on macOS, pressing the left mouse button while holding\n // control results in a mouse event with `button` set to 2 (incorrectly\n // indicating the right mouse button) but `buttons` set to 1 (correctly\n // indicating that only the left mouse button is down). This attempts to\n // reverse that translation.\n //\n // https://github.com/google/neuroglancer/issues/365\n //\n // Notes:\n //\n // - If both the left and right mouse buttons are both pressed at the same\n // time, this method of disambiguation does not work.\n //\n // - Firefox seems to \"remember\" that this translation of the button\n // number was done, and also sends the `mouseup` event with a button\n // number of 2, even if the control key was released before releasing\n // the mouse button. That means `mouse_drag.ts` works unmodified with\n // this translation (since it waits for a mouseup event with the same\n // button number).\n //\n // - This method of disambiguation does not work for `mouseup` events,\n // since the button has already been released and therefore is not\n // included in `buttons` anyway. Fortunately `mouseup` events are not\n // commonly used in Neuroglancer.\n if (button === 2 && (event.buttons & 3) === 1) {\n // `button` is 2 (right button), but only the left button is currently pressed.\n button = 0;\n }\n this.dispatch(`mousedown${button}`, event);\n });\n this.registerEventListener(target, \"mouseup\", (event: MouseEvent) => {\n if (commonHandler !== undefined) commonHandler(event);\n this.dispatch(`mouseup${event.button}`, event);\n });\n }\n}\n\nexport { EventActionMap, registerActionListener };\nexport type { EventActionMapInterface, ActionEvent };\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport type RelativeDragHandler = (\n event: MouseEvent,\n deltaX: number,\n deltaY: number,\n) => void;\nexport function startRelativeMouseDrag(\n initialEvent: MouseEvent,\n handler: RelativeDragHandler,\n finishDragHandler?: RelativeDragHandler,\n) {\n const { document } = initialEvent.view!;\n let prevClientX = initialEvent.clientX;\n let prevClientY = initialEvent.clientY;\n const mouseMoveHandler = (e: PointerEvent) => {\n const deltaX = e.clientX - prevClientX;\n const deltaY = e.clientY - prevClientY;\n prevClientX = e.clientX;\n prevClientY = e.clientY;\n handler(e, deltaX, deltaY);\n };\n const button = initialEvent.button;\n const cancel = (e: PointerEvent) => {\n document.removeEventListener(\"pointermove\", mouseMoveHandler, true);\n document.removeEventListener(\"pointerup\", mouseUpHandler, false);\n\n if (finishDragHandler !== undefined) {\n finishDragHandler(e, e.clientX - prevClientX, e.clientY - prevClientY);\n }\n };\n const mouseUpHandler = (e: PointerEvent) => {\n if (e.button === button) {\n cancel(e);\n }\n };\n document.addEventListener(\"pointermove\", mouseMoveHandler, true);\n document.addEventListener(\"pointerup\", mouseUpHandler, false);\n document.addEventListener(\"pointercancel\", cancel, false);\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nconst DOM_DELTA_PIXEL = 0;\nconst DOM_DELTA_LINE = 1;\nconst DOM_DELTA_PAGE = 2;\n\nexport function getWheelZoomAmount(event: WheelEvent) {\n let multiplier = 0;\n const { deltaMode } = event;\n switch (deltaMode) {\n case DOM_DELTA_PIXEL:\n multiplier = 1 / 200.0;\n break;\n case DOM_DELTA_LINE:\n multiplier = 1 / 10.0;\n break;\n case DOM_DELTA_PAGE:\n multiplier = 2;\n break;\n }\n return Math.exp(event.deltaY * multiplier);\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Facilities for drawing quads in WebGL as two triangles.\n */\n\nexport const VERTICES_PER_QUAD = 6;\nexport const TRIANGLES_PER_QUAD = 2;\n\n// Use a lookup table rather than a switch to avoid miscompilation on Apple M1.\nexport const glsl_getQuadVertexPosition = `\nvec2 getQuadVertexPosition(vec2 lower, vec2 upper) {\n const vec2 coeffs[] = vec2[](\n vec2(0.0, 0.0),\n vec2(0.0, 1.0),\n vec2(1.0, 1.0),\n vec2(1.0, 1.0),\n vec2(1.0, 0.0),\n vec2(0.0, 0.0)\n );\n int v = gl_VertexID % 6;\n return mix(lower, upper, coeffs[v]);\n}\n`;\n\nexport function drawQuads(\n gl: WebGL2RenderingContext,\n quadsPerInstance: number,\n numInstances: number,\n) {\n gl.drawArraysInstanced(\n WebGL2RenderingContext.TRIANGLES,\n 0,\n VERTICES_PER_QUAD * quadsPerInstance,\n numInstances,\n );\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Facilities for drawing anti-aliased lines in WebGL as quads.\n */\n\nimport {\n drawQuads,\n glsl_getQuadVertexPosition,\n VERTICES_PER_QUAD,\n} from \"#src/webgl/quad.js\";\nimport type { ShaderBuilder, ShaderProgram } from \"#src/webgl/shader.js\";\nimport { glsl_clipLineToDepthRange } from \"#src/webgl/shader_lib.js\";\n\nexport const VERTICES_PER_LINE = VERTICES_PER_QUAD;\n\nexport function defineLineShader(builder: ShaderBuilder, rounded = false) {\n builder.addVertexCode(glsl_getQuadVertexPosition);\n // x: 1 / viewportWidth\n // y: 1 / viewportHeight\n // z: featherWidth: Line feather width in pixels\n builder.addUniform(\"highp vec3\", \"uLineParams\");\n builder.addVarying(\"highp float\", \"vLineCoord\");\n // max(1e-6, featherWidth) / (lineWidth + featherWidth)\n builder.addVarying(\"highp float\", \"vLineFeatherFraction\");\n if (rounded) {\n // Fraction of total line length used by each endpoint.\n builder.addVarying(\"highp float\", \"vEndpointFraction\");\n builder.addVarying(\"highp float\", \"vLineCoordT\");\n // Starting point of border from [0, 1].\n builder.addVarying(\"highp float\", \"vLineBorderStartFraction\");\n }\n builder.addVertexCode(glsl_clipLineToDepthRange);\n builder.addVertexCode(`\nvec2 getLineOffset() { return getQuadVertexPosition(vec2(0.0, -1.0), vec2(1.0, 1.0)); }\nfloat getLineEndpointCoefficient() { return getLineOffset().x; }\nuint getLineEndpointIndex() { return uint(getLineEndpointCoefficient()); }\nvoid emitLine(vec4 vertexAClip, vec4 vertexBClip, float lineWidthInPixels\n ${rounded ? \", float borderWidth\" : \"\"}) {\n if (!clipLineToDepthRange(vertexAClip, vertexBClip)) {\n gl_Position = vec4(2.0, 2.0, 2.0, 1.0);\n return;\n }\n vec3 vertexADevice = vertexAClip.xyz / vertexAClip.w;\n vec3 vertexBDevice = vertexBClip.xyz / vertexBClip.w;\n\n vec2 lineDirectionUnnormalized = vertexBDevice.xy - vertexADevice.xy;\n vec2 lineDirection;\n float linePixelLength = length(lineDirectionUnnormalized / uLineParams.xy * 0.5);\n\n if (linePixelLength < 1e-3) {\n lineDirection = vec2(1.0, 0.0);\n vertexADevice.z = vertexBDevice.z = 0.0;\n } else {\n lineDirection = normalize(lineDirectionUnnormalized);\n }\n vec2 lineNormal = normalize(vec2(lineDirection.y, -lineDirection.x) / uLineParams.yx * uLineParams.xy);\n\n vec2 lineOffset = getLineOffset();\n gl_Position = vec4(mix(vertexADevice, vertexBDevice, lineOffset.x), 1.0);\n float totalLineWidth = lineWidthInPixels + 2.0 * uLineParams.z ${\n rounded ? \" + 2.0 * borderWidth\" : \"\"\n };\n if (lineWidthInPixels == 0.0) totalLineWidth = 0.0;\n vLineFeatherFraction = max(1e-6, uLineParams.z) / totalLineWidth;\n gl_Position.xy += (lineOffset.y * lineNormal\n ${\n rounded\n ? \"+ lineDirection * (2.0 * lineOffset.x - 1.0)\"\n : \"\"\n })\n * totalLineWidth * uLineParams.xy;\n vLineCoord = lineOffset.y;\n ${\n rounded\n ? \"vEndpointFraction = totalLineWidth / (linePixelLength + totalLineWidth * 2.0);\"\n : \"\"\n }\n ${\n rounded\n ? \"vLineCoordT = lineOffset.x; vLineBorderStartFraction = lineWidthInPixels / totalLineWidth;\"\n : \"\"\n }\n}\nvoid emitLine(mat4 projection, vec3 vertexA, vec3 vertexB, float lineWidthInPixels\n ${rounded ? \", float borderWidth\" : \"\"}) {\n emitLine(projection * vec4(vertexA, 1.0), projection * vec4(vertexB, 1.0),\n lineWidthInPixels\n ${rounded ? \", borderWidth\" : \"\"});\n}\n`);\n if (rounded) {\n builder.addFragmentCode(`\nvec4 getRoundedLineColor(vec4 interiorColor, vec4 borderColor) {\n float radius;\n if (vLineCoordT < vEndpointFraction || vLineCoordT > 1.0 - vEndpointFraction) {\n radius = length(vec2(1.0 - min(vLineCoordT, 1.0 - vLineCoordT) / vEndpointFraction,\n vLineCoord));\n if (radius > 1.0) {\n discard;\n }\n } else {\n radius = abs(vLineCoord);\n }\n float borderColorFraction = clamp((radius - vLineBorderStartFraction) / vLineFeatherFraction, 0.0, 1.0);\n float feather = clamp((1.0 - radius) / vLineFeatherFraction, 0.0, 1.0);\n vec4 color = mix(interiorColor, borderColor, borderColorFraction);\n return vec4(color.rgb, color.a * feather);\n}\n`);\n }\n\n builder.addFragmentCode(`\nfloat getLineAlpha() {\n return clamp((1.0 - abs(vLineCoord)) / vLineFeatherFraction, 0.0, 1.0);\n}\n`);\n}\n\nexport function drawLines(\n gl: WebGL2RenderingContext,\n linesPerInstance: number,\n numInstances: number,\n) {\n drawQuads(gl, linesPerInstance, numInstances);\n}\n\nexport function initializeLineShader(\n shader: ShaderProgram,\n projectionParameters: { width: number; height: number },\n featherWidthInPixels: number,\n) {\n const { gl } = shader;\n gl.uniform3f(\n shader.uniform(\"uLineParams\"),\n 1 / projectionParameters.width,\n 1 / projectionParameters.height,\n featherWidthInPixels,\n );\n}\n","/**\n * @license\n * Copyright 2024 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getMemoizedBuffer } from \"#src/webgl/buffer.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport { VERTICES_PER_QUAD } from \"#src/webgl/quad.js\";\n\n/**\n * Create a Float32Array of vertices gridded in a rectangle\n * Only grids along the x-axis are created, the y-axis is assumed to be the same for all grids\n */\nexport function createGriddedRectangleArray(\n numGrids: number,\n startX = -1,\n endX = 1,\n startY = 1,\n endY = -1,\n): Float32Array {\n const result = new Float32Array(numGrids * VERTICES_PER_QUAD * 2);\n const step = (endX - startX) / numGrids;\n let currentx = startX;\n for (let i = 0; i < numGrids; ++i) {\n const index = i * VERTICES_PER_QUAD * 2;\n\n // Triangle 1 - top-left, top-right, bottom-right\n result[index] = currentx; // top-left x\n result[index + 1] = startY; // top-left y\n result[index + 2] = currentx + step; // top-right x\n result[index + 3] = startY; // top-right y\n result[index + 4] = currentx + step; // bottom-right x\n result[index + 5] = endY; // bottom-right y\n\n // Triangle 2 - top-left, bottom-right, bottom-left\n result[index + 6] = currentx; // top-left x\n result[index + 7] = startY; // top-left y\n result[index + 8] = currentx + step; // bottom-right x\n result[index + 9] = endY; // bottom-right y\n result[index + 10] = currentx; // bottom-left x\n result[index + 11] = endY; // bottom-left y\n currentx += step;\n }\n return result;\n}\n\n/**\n * Get a buffer of vertices representing a rectangle that is gridded\n * along the x dimension, useful for drawing grids, such as a lookup table / heatmap\n */\nexport function getGriddedRectangleBuffer(\n gl: GL,\n numGrids: number,\n startX = -1,\n endX = 1,\n startY = 1,\n endY = -1,\n) {\n return getMemoizedBuffer(\n gl,\n WebGL2RenderingContext.ARRAY_BUFFER,\n createGriddedRectangleArray,\n numGrids,\n startX,\n endX,\n startY,\n endY,\n ).value;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Converts an HSV color (with h, s, v in [0,1]) to RGB (in range [0,1]).\n *\n * Based on goog/color/color.js in the Google Closure library.\n */\nexport function hsvToRgb(\n out: Float32Array,\n h: number,\n s: number,\n v: number,\n): Float32Array {\n h *= 6;\n const hueIndex = Math.floor(h);\n const remainder = h - hueIndex;\n const val1 = v * (1 - s);\n const val2 = v * (1 - s * remainder);\n const val3 = v * (1 - s * (1 - remainder));\n switch (hueIndex % 6) {\n case 0:\n out[0] = v;\n out[1] = val3;\n out[2] = val1;\n break;\n case 1:\n out[0] = val2;\n out[1] = v;\n out[2] = val1;\n break;\n case 2:\n out[0] = val1;\n out[1] = v;\n out[2] = val3;\n break;\n case 3:\n out[0] = val1;\n out[1] = val2;\n out[2] = v;\n break;\n case 4:\n out[0] = val3;\n out[1] = val1;\n out[2] = v;\n break;\n case 5:\n out[0] = v;\n out[1] = val1;\n out[2] = val2;\n break;\n }\n return out;\n}\n\n/**\n * Converts from RGB values (with r,g,b in range [0,1]) to an array of HSV values (in range [0, 1])\n *\n * Based on goog/color/color.js in the Google Closure library.\n */\nexport function rgbToHsv(\n out: Float32Array,\n r: number,\n g: number,\n b: number,\n): Float32Array {\n const max = Math.max(Math.max(r, g), b);\n const min = Math.min(Math.min(r, g), b);\n out[2] = max;\n if (min === max) {\n out[0] = 0;\n out[1] = 0;\n } else {\n const delta = max - min;\n out[1] = delta / max;\n\n if (r === max) {\n out[0] = (g - b) / delta;\n } else if (g === max) {\n out[0] = 2 + (b - r) / delta;\n } else {\n out[0] = 4 + (r - g) / delta;\n }\n out[0] /= 6.0;\n if (out[0] < 0.0) {\n out[0] += 1.0;\n }\n if (out[0] > 1.0) {\n out[0] -= 1.0;\n }\n }\n return out;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { parseRGBColorSpecification, serializeColor } from \"#src/util/color.js\";\nimport { hsvToRgb, rgbToHsv } from \"#src/util/colorspace.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { vec3 } from \"#src/util/geom.js\";\n\nexport class ColorWidget<\n Color extends vec3 | undefined = vec3,\n> extends RefCounted {\n static template() {\n const element = document.createElement(\"input\");\n element.classList.add(\"neuroglancer-color-widget\");\n element.type = \"color\";\n return element;\n }\n\n constructor(\n public model: WatchableValueInterface,\n public getDefaultColor: () => vec3 = () => vec3.fromValues(1, 0, 0),\n public element = ColorWidget.template(),\n public unsetHandler = () => {},\n enableWheel = true,\n ) {\n super();\n element.addEventListener(\"change\", () => this.updateModel());\n element.addEventListener(\"input\", () => this.updateModel());\n if (enableWheel) {\n element.addEventListener(\"wheel\", (event) => {\n event.stopPropagation();\n event.preventDefault();\n this.adjustHueViaWheel(event);\n });\n }\n element.addEventListener(\"mousedown\", (evt) => {\n if (evt.button === 2) {\n evt.stopPropagation();\n unsetHandler();\n }\n });\n this.registerDisposer(model.changed.add(() => this.updateView()));\n this.updateView();\n }\n private getRGB() {\n return this.model.value ?? this.getDefaultColor();\n }\n private updateView() {\n this.element.value = serializeColor(this.getRGB());\n }\n private updateModel() {\n this.model.value = parseRGBColorSpecification(this.element.value) as Color;\n }\n\n adjustHueViaWheel(event: WheelEvent) {\n const rgb = this.getRGB();\n const temp = vec3.create();\n rgbToHsv(temp, rgb[0], rgb[1], rgb[2]);\n const { deltaY } = event;\n let hue = Math.round(temp[0] * 256);\n hue += deltaY > 0 ? 1 : deltaY < 0 ? -1 : 0;\n hue = (hue + 256) % 256;\n temp[0] = hue / 256;\n hsvToRgb(temp, temp[0], temp[1], temp[2]);\n this.model.value = temp as Color;\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport function removeChildren(element: HTMLElement) {\n while (true) {\n const child = element.firstChild;\n if (!child) {\n break;\n }\n element.removeChild(child);\n }\n}\n\nexport function removeFromParent(element: HTMLElement) {\n const { parentElement } = element;\n if (parentElement) {\n parentElement.removeChild(element);\n return true;\n }\n return false;\n}\n\nexport function updateInputFieldWidth(\n element: HTMLInputElement,\n length = Math.max(1, element.value.length),\n) {\n const newWidth = `${length}ch`;\n if (element.style.width !== newWidth) {\n // Force additional reflow to work around Chrome bug.\n element.style.width = \"0px\";\n element.offsetWidth;\n element.style.width = newWidth;\n }\n}\n\nexport function updateChildren(\n element: HTMLElement,\n children: Iterable,\n) {\n let nextChild = element.firstElementChild;\n for (const child of children) {\n if (child !== nextChild) {\n element.insertBefore(child, nextChild);\n }\n nextChild = child.nextElementSibling;\n }\n while (nextChild !== null) {\n const next = nextChild.nextElementSibling;\n element.removeChild(nextChild);\n nextChild = next;\n }\n}\n\nexport function isInputTextTarget(target: EventTarget | null) {\n if (!(target instanceof HTMLElement)) return false;\n if (\n target instanceof HTMLInputElement ||\n target instanceof HTMLTextAreaElement ||\n target.isContentEditable\n ) {\n return true;\n }\n return false;\n}\n\nexport function measureElementClone(element: HTMLElement) {\n const clone = element.cloneNode(/*deep=*/ true) as HTMLElement;\n clone.style.position = \"absolute\";\n document.body.appendChild(clone);\n return clone.getBoundingClientRect();\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/icon.css\";\n\nexport interface MakeIconOptions {\n text?: string;\n svg?: string;\n title?: string;\n onClick?: (this: HTMLElement, event: MouseEvent) => void;\n href?: string;\n}\n\nexport interface MakeHoverIconOptions extends MakeIconOptions {\n svgHover?: string;\n}\n\nexport function makeHoverIcon(options: MakeHoverIconOptions): HTMLElement {\n const element = makeIcon(options);\n if (options.svgHover) {\n element.classList.add(\"neuroglancer-icon-hover\");\n element.innerHTML += options.svgHover;\n }\n return element;\n}\n\nexport function makeIcon(options: MakeIconOptions): HTMLElement {\n const { title, onClick, href } = options;\n let element: HTMLDivElement | HTMLAnchorElement;\n if (href !== undefined) {\n element = document.createElement(\"a\");\n element.href = href;\n element.target = \"_blank\";\n } else {\n element = document.createElement(\"div\");\n }\n\n if (title !== undefined) {\n element.title = title;\n }\n if (onClick !== undefined) {\n element.addEventListener(\"click\", onClick);\n }\n const { svg } = options;\n element.className = \"neuroglancer-icon\";\n if (svg !== undefined) {\n element.innerHTML = svg;\n }\n if (options.text !== undefined) {\n element.appendChild(document.createTextNode(options.text));\n }\n return element;\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Tabbed view widget.\n */\n\nimport \"#src/widget/tab_view.css\";\n\nimport type {\n WatchableValueChangeInterface,\n WatchableValueInterface,\n} from \"#src/trackable_value.js\";\nimport { animationFrameDebounce } from \"#src/util/animation_frame_debounce.js\";\nimport type { Owned } from \"#src/util/disposable.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { removeChildren, removeFromParent } from \"#src/util/dom.js\";\nimport { NullarySignal, Signal } from \"#src/util/signal.js\";\nimport type { Trackable } from \"#src/util/trackable.js\";\nimport { WatchableVisibilityPriority } from \"#src/visibility_priority/frontend.js\";\n\nexport class Tab extends RefCounted {\n element = document.createElement(\"div\");\n\n get visible() {\n return this.visibility.visible;\n }\n\n constructor(\n public visibility = new WatchableVisibilityPriority(\n WatchableVisibilityPriority.VISIBLE,\n ),\n ) {\n super();\n const { element } = this;\n element.classList.add(\"neuroglancer-tab-content\");\n }\n\n disposed() {\n removeFromParent(this.element);\n super.disposed();\n }\n}\n\nexport class OptionSpecification extends RefCounted implements Trackable {\n changed = new NullarySignal();\n options = new Map();\n optionsChanged = new NullarySignal();\n\n private selectedValue: string | undefined = undefined;\n private defaultValue: string | undefined = undefined;\n\n get value() {\n const { selectedValue } = this;\n if (selectedValue !== undefined) {\n return selectedValue;\n }\n return this.defaultValue;\n }\n\n set default(value: string | undefined) {\n if (this.defaultValue !== value) {\n this.defaultValue = value;\n this.changed.dispatch();\n }\n }\n\n get default() {\n return this.defaultValue;\n }\n\n set value(value: string | undefined) {\n if (value !== undefined && this.ready_ && !this.options.has(value)) {\n value = undefined;\n }\n const { selectedValue } = this;\n if (selectedValue !== value) {\n this.selectedValue = value;\n this.changed.dispatch();\n }\n }\n\n get validValue() {\n const value = this.selectedValue;\n if (value === undefined || !this.options.has(value)) {\n return this.defaultValue;\n }\n return value;\n }\n\n add(id: string, value: T) {\n const { options } = this;\n if (options.has(id)) {\n throw new Error(`Option already defined: ${JSON.stringify(id)}.`);\n }\n options.set(id, value);\n this.optionsChanged.dispatch();\n if (this.defaultValue === undefined) {\n this.default = id;\n }\n }\n\n remove(id: string) {\n const { options } = this;\n if (!options.has(id)) {\n throw new Error(`Option is not defined: ${JSON.stringify(id)}.`);\n }\n options.delete(id);\n this.optionsChanged.dispatch();\n }\n\n toJSON() {\n const { value, defaultValue } = this;\n if (value === defaultValue) {\n return undefined;\n }\n return value;\n }\n\n reset() {\n this.value = undefined;\n }\n\n ready_ = true;\n\n /**\n * When `ready` is `false`, the selected `value` may be set to an unknown option.\n */\n get ready() {\n return this.ready_;\n }\n\n set ready(value: boolean) {\n if (value !== this.ready_) {\n this.ready_ = value;\n if (value) {\n // eslint-disable-next-line no-self-assign\n this.value = this.value;\n }\n this.changed.dispatch();\n }\n }\n\n restoreState(obj: any) {\n if (typeof obj !== \"string\") {\n obj = undefined;\n }\n this.value = obj;\n }\n}\n\nexport class StackView extends RefCounted {\n element = document.createElement(\"div\");\n tabs = new Map>();\n tabVisibilityChanged = new Signal<(id: TabId, visible: boolean) => void>();\n\n private displayedTab: TabId | undefined;\n\n get visible() {\n return this.visibility.visible;\n }\n\n private debouncedUpdateSelectedTab = this.registerCancellable(\n animationFrameDebounce(() => this.updateSelectedTab()),\n );\n\n flush() {\n this.debouncedUpdateSelectedTab.flush();\n }\n\n constructor(\n public getter: (id: TabId) => Owned,\n public selected: WatchableValueInterface,\n public visibility = new WatchableVisibilityPriority(\n WatchableVisibilityPriority.VISIBLE,\n ),\n public invalidateByDefault = false,\n ) {\n super();\n\n const { element } = this;\n element.className = \"neuroglancer-stack-view\";\n this.registerDisposer(\n visibility.changed.add(this.debouncedUpdateSelectedTab),\n );\n this.registerDisposer(\n selected.changed.add(this.debouncedUpdateSelectedTab),\n );\n this.updateSelectedTab();\n }\n\n invalidate(id: TabId) {\n const { tabs } = this;\n const tab = tabs.get(id);\n if (tab === undefined) {\n return;\n }\n tab.dispose();\n tabs.delete(id);\n if (id === this.displayedTab) {\n this.displayedTab = undefined;\n this.debouncedUpdateSelectedTab();\n }\n }\n\n private hideTab(id: TabId) {\n const tab = this.tabs.get(id);\n if (tab !== undefined) {\n tab.visibility.value = WatchableVisibilityPriority.IGNORED;\n tab.element.style.display = \"none\";\n }\n this.tabVisibilityChanged.dispatch(id, false);\n }\n\n private showTab(id: TabId) {\n const { tabs } = this;\n let tab = tabs.get(id);\n if (tab === undefined) {\n tab = this.getter(id);\n this.element.appendChild(tab.element);\n tabs.set(id, tab);\n }\n tab.element.style.display = \"\";\n tab.visibility.value = WatchableVisibilityPriority.VISIBLE;\n this.tabVisibilityChanged.dispatch(id, true);\n }\n\n private updateSelectedTab() {\n const { displayedTab } = this;\n const newTab = this.visible ? this.selected.value : undefined;\n if (\n newTab === displayedTab &&\n (newTab === undefined || this.tabs.has(newTab))\n ) {\n return;\n }\n if (displayedTab !== undefined) {\n this.hideTab(displayedTab);\n }\n if (this.invalidateByDefault) {\n this.invalidateAll();\n }\n this.displayedTab = newTab;\n if (newTab === undefined) {\n return;\n }\n this.showTab(newTab);\n }\n\n invalidateAll(predicate: ((id: TabId) => boolean) | undefined = undefined) {\n const { tabs } = this;\n for (const [id, tab] of tabs) {\n if (predicate?.(id)) continue;\n tabs.delete(id);\n tab.dispose();\n }\n this.debouncedUpdateSelectedTab();\n }\n\n disposed() {\n this.invalidateAll();\n removeFromParent(this.element);\n super.disposed();\n }\n}\n\nexport class TabSpecification extends OptionSpecification<{\n label: string;\n order?: number;\n getter: () => Owned;\n hidden?: WatchableValueInterface;\n}> {}\n\nfunction updateTabLabelVisibilityStyle(\n labelElement: HTMLElement,\n visible: boolean,\n) {\n const className = \"neuroglancer-selected-tab-label\";\n if (visible) {\n labelElement.classList.add(className);\n } else {\n labelElement.classList.remove(className);\n }\n}\n\nexport interface TabViewOptions {\n makeTab: (id: string) => Tab;\n selectedTab: WatchableValueInterface;\n tabs: WatchableValueChangeInterface<\n { id: string; label: string; hidden: boolean }[]\n >;\n handleTabElement?: (id: string, element: HTMLElement) => void;\n}\n\nexport class TabView extends RefCounted {\n element = document.createElement(\"div\");\n tabBar = document.createElement(\"div\");\n\n tabs: WatchableValueChangeInterface<\n { id: string; label: string; hidden: boolean }[]\n >;\n selectedTab: WatchableValueInterface;\n private handleTabElement:\n | ((id: string, element: HTMLElement) => void)\n | undefined;\n\n private stack: StackView;\n private tabLabels = new Map();\n private tabsGeneration = -1;\n\n get visible() {\n return this.visibility.visible;\n }\n\n private debouncedUpdateView = this.registerCancellable(\n animationFrameDebounce(() => this.updateTabs()),\n );\n\n constructor(\n options: TabViewOptions,\n public visibility = new WatchableVisibilityPriority(\n WatchableVisibilityPriority.VISIBLE,\n ),\n ) {\n super();\n this.tabs = options.tabs;\n this.selectedTab = options.selectedTab;\n this.handleTabElement = options.handleTabElement;\n const { element, tabBar } = this;\n element.className = \"neuroglancer-tab-view\";\n tabBar.className = \"neuroglancer-tab-view-bar\";\n element.appendChild(tabBar);\n this.registerDisposer(visibility.changed.add(this.debouncedUpdateView));\n const stack = (this.stack = this.registerDisposer(\n new StackView(\n options.makeTab,\n options.selectedTab,\n this.visibility,\n ),\n ));\n element.appendChild(stack.element);\n this.registerDisposer(options.tabs.changed.add(this.debouncedUpdateView));\n let prevSelectedId = this.selectedTab.value;\n this.registerDisposer(\n options.selectedTab.changed.add(() => {\n const tabs = this.tabs.value;\n const prevSelectedTab = tabs.find(({ id }) => id === prevSelectedId);\n if (prevSelectedTab?.hidden) {\n // hide hidden tab label when it is deselected\n this.tabs.changed.count++;\n this.debouncedUpdateView();\n } else {\n this.updateTabLabelStyles();\n }\n prevSelectedId = this.selectedTab.value;\n }),\n );\n this.updateTabs();\n }\n\n private updateTabLabelStyles() {\n const selectedId = this.selectedTab.value;\n for (const [id, element] of this.tabLabels) {\n updateTabLabelVisibilityStyle(element, id === selectedId);\n }\n }\n\n private updateTabs() {\n if (this.tabsGeneration !== this.tabs.changed.count) {\n this.destroyTabs();\n if (this.visible) {\n this.makeTabs();\n }\n }\n }\n\n private destroyTabs() {\n if (this.tabsGeneration === -1) {\n return;\n }\n this.tabLabels.clear();\n if (!this.visible) {\n this.stack.invalidateAll();\n } else {\n const tabs = this.tabs.value;\n this.stack.invalidateAll(\n (existingId) => tabs.find(({ id }) => id === existingId) !== undefined,\n );\n }\n removeChildren(this.tabBar);\n this.tabsGeneration = -1;\n }\n\n private makeTabs() {\n const { tabBar, tabLabels, handleTabElement } = this;\n for (const { id, label, hidden } of this.tabs.value) {\n if (hidden && id !== this.selectedTab.value) continue;\n const labelElement = document.createElement(\"div\");\n labelElement.classList.add(\"neuroglancer-tab-label\");\n labelElement.textContent = label;\n labelElement.addEventListener(\"click\", () => {\n this.selectedTab.value = id;\n });\n if (handleTabElement !== undefined) {\n handleTabElement(id, labelElement);\n }\n tabLabels.set(id, labelElement);\n tabBar.appendChild(labelElement);\n }\n this.updateTabLabelStyles();\n this.tabsGeneration = this.tabs.changed.count;\n }\n\n disposed() {\n removeChildren(this.tabBar);\n this.tabLabels.clear();\n removeFromParent(this.element);\n super.disposed();\n }\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/invlerp.css\";\n\nimport svg_arrowLeft from \"ikonate/icons/arrow-left.svg?raw\";\nimport svg_arrowRight from \"ikonate/icons/arrow-right.svg?raw\";\nimport type { DisplayContext } from \"#src/display_context.js\";\nimport { IndirectRenderedPanel } from \"#src/display_context.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport type { ToolActivation } from \"#src/ui/tool.js\";\nimport { animationFrameDebounce } from \"#src/util/animation_frame_debounce.js\";\nimport type { DataType } from \"#src/util/data_type.js\";\nimport type { Owned } from \"#src/util/disposable.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { removeChildren, updateInputFieldWidth } from \"#src/util/dom.js\";\nimport {\n EventActionMap,\n registerActionListener,\n} from \"#src/util/event_action_map.js\";\nimport type { DataTypeInterval } from \"#src/util/lerp.js\";\nimport {\n computeInvlerp,\n computeLerp,\n dataTypeCompare,\n dataTypeIntervalEqual,\n getClampedInterval,\n getClosestEndpoint,\n getIntervalBoundsEffectiveFraction,\n getIntervalBoundsEffectiveOffset,\n parseDataTypeValue,\n} from \"#src/util/lerp.js\";\nimport { MouseEventBinder } from \"#src/util/mouse_bindings.js\";\nimport { startRelativeMouseDrag } from \"#src/util/mouse_drag.js\";\nimport { Uint64 } from \"#src/util/uint64.js\";\nimport { getWheelZoomAmount } from \"#src/util/wheel_zoom.js\";\nimport type { WatchableVisibilityPriority } from \"#src/visibility_priority/frontend.js\";\nimport { getMemoizedBuffer } from \"#src/webgl/buffer.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { ParameterizedEmitterDependentShaderGetter } from \"#src/webgl/dynamic_shader.js\";\nimport { parameterizedEmitterDependentShaderGetter } from \"#src/webgl/dynamic_shader.js\";\nimport type { HistogramSpecifications } from \"#src/webgl/empirical_cdf.js\";\nimport {\n defineLerpShaderFunction,\n enableLerpShaderFunction,\n} from \"#src/webgl/lerp.js\";\nimport {\n defineLineShader,\n drawLines,\n initializeLineShader,\n VERTICES_PER_LINE,\n} from \"#src/webgl/lines.js\";\nimport { ShaderBuilder } from \"#src/webgl/shader.js\";\nimport { getShaderType } from \"#src/webgl/shader_lib.js\";\nimport type { InvlerpParameters } from \"#src/webgl/shader_ui_controls.js\";\nimport { getSquareCornersBuffer } from \"#src/webgl/square_corners_buffer.js\";\nimport { setRawTextureParameters } from \"#src/webgl/texture.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\nimport type { LayerControlTool } from \"#src/widget/layer_control.js\";\nimport type { LegendShaderOptions } from \"#src/widget/shader_controls.js\";\nimport { Tab } from \"#src/widget/tab_view.js\";\n\nconst inputEventMap = EventActionMap.fromObject({\n \"shift?+mousedown0\": { action: \"set\" },\n \"shift?+alt+mousedown0\": { action: \"adjust-window-via-drag\" },\n \"shift?+wheel\": { action: \"zoom-via-wheel\" },\n});\n\nexport function createCDFLineShader(gl: GL, textureUnit: symbol) {\n const builder = new ShaderBuilder(gl);\n defineLineShader(builder);\n builder.addTextureSampler(\"sampler2D\", \"uHistogramSampler\", textureUnit);\n builder.addOutputBuffer(\"vec4\", \"out_color\", 0);\n builder.addAttribute(\"uint\", \"aDataValue\");\n builder.addUniform(\"float\", \"uBoundsFraction\");\n builder.addVertexCode(`\nfloat getCount(int i) {\n return texelFetch(uHistogramSampler, ivec2(i, 0), 0).x;\n}\nvec4 getVertex(float cdf, int i) {\n float x;\n if (i == 0) {\n x = -1.0;\n } else if (i == 255) {\n x = 1.0;\n } else {\n x = float(i) / 254.0 * uBoundsFraction * 2.0 - 1.0;\n }\n return vec4(x, cdf * (2.0 - uLineParams.y) - 1.0 + uLineParams.y * 0.5, 0.0, 1.0);\n}\n`);\n builder.setVertexMain(`\nint lineNumber = int(aDataValue);\nint dataValue = lineNumber;\nfloat cumSum = 0.0;\nfor (int i = 0; i <= dataValue; ++i) {\n cumSum += getCount(i);\n}\nfloat total = cumSum + getCount(dataValue + 1);\nfloat cumSumEnd = dataValue == ${NUM_CDF_LINES - 1} ? cumSum : total;\nif (dataValue == ${NUM_CDF_LINES - 1}) {\n cumSum + getCount(dataValue + 1);\n}\nfor (int i = dataValue + 2; i < 256; ++i) {\n total += getCount(i);\n}\ntotal = max(total, 1.0);\nfloat cdf1 = cumSum / total;\nfloat cdf2 = cumSumEnd / total;\nemitLine(getVertex(cdf1, lineNumber), getVertex(cdf2, lineNumber + 1), 1.0);\n`);\n builder.setFragmentMain(`\nout_color = vec4(0.0, 1.0, 1.0, getLineAlpha());\n`);\n return builder.build();\n}\n\nexport class CdfController<\n T extends RangeAndWindowIntervals,\n> extends RefCounted {\n constructor(\n public element: HTMLElement,\n public dataType: DataType,\n public getModel: () => T,\n public setModel: (value: T) => void,\n ) {\n super();\n element.title = inputEventMap.describe();\n this.registerDisposer(new MouseEventBinder(element, inputEventMap));\n registerActionListener(element, \"set\", (actionEvent) => {\n const mouseEvent = actionEvent.detail;\n const bounds = this.getModel();\n const value = this.getTargetValue(mouseEvent);\n if (value === undefined) return;\n const clampedRange = getClampedInterval(bounds.window, bounds.range);\n const endpointIndex = getClosestEndpoint(clampedRange, value);\n const setEndpoint = (value: number | Uint64) => {\n const bounds = this.getModel();\n this.setModel(\n getUpdatedRangeAndWindowParameters(\n bounds,\n \"range\",\n endpointIndex,\n value,\n ),\n );\n };\n setEndpoint(value);\n startRelativeMouseDrag(mouseEvent, (newEvent: MouseEvent) => {\n const value = this.getTargetValue(newEvent);\n if (value === undefined) return;\n setEndpoint(value);\n });\n });\n\n registerActionListener(\n element,\n \"adjust-window-via-drag\",\n (actionEvent) => {\n // If user starts drag on left half, then right bound is fixed, and left bound is adjusted to\n // keep the value under the mouse fixed. If user starts drag on right half, the left bound is\n // fixed and right bound is adjusted.\n const mouseEvent = actionEvent.detail;\n const initialRelativeX = this.getTargetFraction(mouseEvent);\n const initialValue = this.getWindowLerp(initialRelativeX);\n // Index for bound being adjusted\n const endpointIndex = initialRelativeX < 0.5 ? 0 : 1;\n const setEndpoint = (value: number | Uint64) => {\n const bounds = this.getModel();\n this.setModel(\n getUpdatedRangeAndWindowParameters(\n bounds,\n \"window\",\n endpointIndex,\n value,\n ),\n );\n };\n startRelativeMouseDrag(mouseEvent, (newEvent: MouseEvent) => {\n const window = this.getModel().window;\n const relativeX = this.getTargetFraction(newEvent);\n if (endpointIndex === 0) {\n // Need to find x such that: lerp([x, window[1]], relativeX) == initialValue\n // Equivalently: lerp([initialValue, window[1]], -relativeX / ( 1 - relativeX))\n setEndpoint(\n computeLerp(\n [initialValue, window[1]] as DataTypeInterval,\n this.dataType,\n -relativeX / (1 - relativeX),\n ),\n );\n } else {\n // Need to find x such that: lerp([window[0], x], relativeX) == initialValue\n // Equivalently: lerp([window[0], initialValue], 1 / relativeX)\n setEndpoint(\n computeLerp(\n [window[0], initialValue] as DataTypeInterval,\n this.dataType,\n 1 / relativeX,\n ),\n );\n }\n });\n },\n );\n\n registerActionListener(\n element,\n \"zoom-via-wheel\",\n (actionEvent) => {\n const wheelEvent = actionEvent.detail;\n const zoomAmount = getWheelZoomAmount(wheelEvent);\n const relativeX = this.getTargetFraction(wheelEvent);\n const { dataType } = this;\n const bounds = this.getModel();\n const newLower = computeLerp(\n bounds.window,\n dataType,\n relativeX * (1 - zoomAmount),\n );\n const newUpper = computeLerp(\n bounds.window,\n dataType,\n (1 - relativeX) * zoomAmount + relativeX,\n );\n this.setModel({\n ...bounds,\n window: [newLower, newUpper] as DataTypeInterval,\n range: bounds.range,\n });\n },\n );\n }\n\n /**\n * Get fraction of distance in x along bounding rect for a MouseEvent.\n */\n getTargetFraction(event: MouseEvent) {\n const clientRect = this.element.getBoundingClientRect();\n return (event.clientX - clientRect.left) / clientRect.width;\n }\n\n /**\n * Interpolate a value along the model interval.\n * @param relativeX Relative x coordinate within the interval.\n * @returns Interpolated value.\n */\n getWindowLerp(relativeX: number) {\n return computeLerp(this.getModel().window, this.dataType, relativeX);\n }\n\n getTargetValue(event: MouseEvent): number | Uint64 | undefined {\n const targetFraction = this.getTargetFraction(event);\n if (!Number.isFinite(targetFraction)) return undefined;\n return this.getWindowLerp(targetFraction);\n }\n}\n\nconst histogramSamplerTextureUnit = Symbol(\"histogramSamplerTexture\");\n\n/**\n * An interval with coordinates `range` and endpoint values `window`.\n * Can be thought of representing associated intervals in x (range) and y (window).\n */\nexport interface RangeAndWindowIntervals {\n range: DataTypeInterval;\n window: DataTypeInterval;\n}\n\n/**\n * Update the value of one endpoint, and return new interval.\n * @param existingBounds Initial bounds.\n * @param boundType 'range' to update endpoint coordinates, 'window' to update endpoint values.\n * @param endpointIndex Index of bound to update.\n * @param newEndpoint New value of bound being updated.\n * @param fitRangeInWindow\n * @returns New bounds.\n */\nexport function getUpdatedRangeAndWindowParameters<\n T extends RangeAndWindowIntervals,\n>(\n existingBounds: T,\n boundType: \"range\" | \"window\",\n endpointIndex: number,\n newEndpoint: number | Uint64,\n fitRangeInWindow = false,\n): T {\n const newBounds = { ...existingBounds };\n const existingInterval = existingBounds[boundType];\n newBounds[boundType] = [\n existingInterval[0],\n existingInterval[1],\n ] as DataTypeInterval;\n // Update bound\n newBounds[boundType][endpointIndex] = newEndpoint;\n if (\n boundType === \"window\" &&\n dataTypeCompare(newEndpoint, existingInterval[1 - endpointIndex]) *\n (2 * endpointIndex - 1) <\n 0\n ) {\n // If new endpoint has gone past other bound, adjust other bound to match\n newBounds[boundType][1 - endpointIndex] = newEndpoint;\n }\n if (boundType === \"range\" && fitRangeInWindow) {\n // Also adjust `window` endpoint to contain the new endpoint.\n const newWindowInterval = [\n existingBounds.window[0],\n existingBounds.window[1],\n ] as DataTypeInterval;\n for (let i = 0; i < 2; ++i) {\n if (\n dataTypeCompare(newEndpoint, newWindowInterval[i]) * (2 * i - 1) >\n 0\n ) {\n newWindowInterval[i] = newEndpoint;\n }\n }\n newBounds.window = newWindowInterval;\n }\n return newBounds;\n}\n\n// 256 bins in total. The first and last bin are for values below the lower bound/above the upper\n// bound.\nconst NUM_HISTOGRAM_BINS_IN_RANGE = 254;\nexport const NUM_CDF_LINES = NUM_HISTOGRAM_BINS_IN_RANGE + 1;\n\n/**\n * Panel that shows Cumulative Distribution Function (CDF) of visible data.\n */\nclass CdfPanel extends IndirectRenderedPanel {\n get drawOrder() {\n return 100;\n }\n controller = this.registerDisposer(\n new CdfController(\n this.element,\n this.parent.dataType,\n () => this.parent.trackable.value,\n (value: InvlerpParameters) => {\n this.parent.trackable.value = value;\n },\n ),\n );\n constructor(public parent: InvlerpWidget) {\n super(parent.display, document.createElement(\"div\"), parent.visibility);\n const { element } = this;\n element.classList.add(\"neuroglancer-invlerp-cdfpanel\");\n }\n\n private dataValuesBuffer = this.registerDisposer(\n getMemoizedBuffer(this.gl, WebGL2RenderingContext.ARRAY_BUFFER, () => {\n const array = new Uint8Array(NUM_CDF_LINES * VERTICES_PER_LINE);\n for (let i = 0; i < NUM_CDF_LINES; ++i) {\n for (let j = 0; j < VERTICES_PER_LINE; ++j) {\n array[i * VERTICES_PER_LINE + j] = i;\n }\n }\n return array;\n }),\n ).value;\n\n private lineShader = this.registerDisposer(\n (() => createCDFLineShader(this.gl, histogramSamplerTextureUnit))(),\n );\n\n private regionCornersBuffer = getSquareCornersBuffer(this.gl, 0, -1, 1, 1);\n\n private regionShader = this.registerDisposer(\n (() => {\n const builder = new ShaderBuilder(this.gl);\n builder.addAttribute(\"vec2\", \"aVertexPosition\");\n builder.addUniform(\"vec2\", \"uBounds\");\n builder.addUniform(\"vec4\", \"uColor\");\n builder.addOutputBuffer(\"vec4\", \"out_color\", 0);\n builder.setVertexMain(`\ngl_Position = vec4(mix(uBounds[0], uBounds[1], aVertexPosition.x) * 2.0 - 1.0, aVertexPosition.y, 0.0, 1.0);\n`);\n builder.setFragmentMain(`\nout_color = uColor;\n`);\n return builder.build();\n })(),\n );\n\n drawIndirect() {\n const {\n lineShader,\n gl,\n regionShader,\n parent: {\n dataType,\n trackable: { value: bounds },\n },\n } = this;\n this.setGLLogicalViewport();\n gl.clearColor(0.0, 0.0, 0.0, 0.0);\n gl.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT);\n gl.enable(WebGL2RenderingContext.BLEND);\n gl.blendFunc(\n WebGL2RenderingContext.SRC_ALPHA,\n WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA,\n );\n gl.disable(WebGL2RenderingContext.DEPTH_TEST);\n gl.disable(WebGL2RenderingContext.STENCIL_TEST);\n {\n regionShader.bind();\n gl.uniform4f(regionShader.uniform(\"uColor\"), 0.2, 0.2, 0.2, 1.0);\n const fraction0 = computeInvlerp(bounds.window, bounds.range[0]);\n const fraction1 = computeInvlerp(bounds.window, bounds.range[1]);\n const effectiveFraction = getIntervalBoundsEffectiveFraction(\n dataType,\n bounds.window,\n );\n gl.uniform2f(\n regionShader.uniform(\"uBounds\"),\n Math.min(fraction0, fraction1) * effectiveFraction,\n Math.max(fraction0, fraction1) * effectiveFraction +\n (1 - effectiveFraction),\n );\n const aVertexPosition = regionShader.attribute(\"aVertexPosition\");\n this.regionCornersBuffer.bindToVertexAttrib(\n aVertexPosition,\n /*componentsPerVertexAttribute=*/ 2,\n /*attributeType=*/ WebGL2RenderingContext.FLOAT,\n );\n gl.drawArrays(WebGL2RenderingContext.TRIANGLE_FAN, 0, 4);\n gl.disableVertexAttribArray(aVertexPosition);\n }\n if (this.parent.histogramSpecifications.producerVisibility.visible) {\n const { renderViewport } = this;\n lineShader.bind();\n initializeLineShader(\n lineShader,\n {\n width: renderViewport.logicalWidth,\n height: renderViewport.logicalHeight,\n },\n /*featherWidthInPixels=*/ 1.0,\n );\n const histogramTextureUnit = lineShader.textureUnit(\n histogramSamplerTextureUnit,\n );\n gl.uniform1f(\n lineShader.uniform(\"uBoundsFraction\"),\n getIntervalBoundsEffectiveFraction(dataType, bounds.window),\n );\n gl.activeTexture(WebGL2RenderingContext.TEXTURE0 + histogramTextureUnit);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, this.parent.texture);\n setRawTextureParameters(gl);\n const aDataValue = lineShader.attribute(\"aDataValue\");\n this.dataValuesBuffer.bindToVertexAttribI(\n aDataValue,\n /*componentsPerVertexAttribute=*/ 1,\n /*attributeType=*/ WebGL2RenderingContext.UNSIGNED_BYTE,\n );\n drawLines(gl, /*linesPerInstance=*/ NUM_CDF_LINES, /*numInstances=*/ 1);\n gl.disableVertexAttribArray(aDataValue);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, null);\n }\n gl.disable(WebGL2RenderingContext.BLEND);\n }\n\n isReady() {\n return true;\n }\n}\n\nfunction dummyColorLegendShaderModule() {}\n\nclass ColorLegendPanel extends IndirectRenderedPanel {\n private shaderOptions: LegendShaderOptions;\n constructor(public parent: InvlerpWidget) {\n super(parent.display, document.createElement(\"div\"), parent.visibility);\n const { element } = this;\n element.classList.add(\"neuroglancer-invlerp-legend-panel\");\n const shaderOptions = (this.shaderOptions = parent.legendShaderOptions!);\n this.shaderGetter = parameterizedEmitterDependentShaderGetter(\n this,\n this.gl,\n {\n ...shaderOptions,\n memoizeKey: { id: \"colorLegendShader\", base: shaderOptions.memoizeKey },\n defineShader: (builder, parameters, extraParameters) => {\n builder.addOutputBuffer(\"vec4\", \"v4f_fragData0\", 0);\n builder.addAttribute(\"vec2\", \"aVertexPosition\");\n builder.addUniform(\"float\", \"uLegendOffset\");\n builder.addVarying(\"float\", \"vLinearPosition\");\n builder.setVertexMain(`\ngl_Position = vec4(aVertexPosition, 0.0, 1.0);\nvLinearPosition = -uLegendOffset + ((aVertexPosition.x + 1.0) * 0.5) * (1.0 + 2.0 * uLegendOffset);\n`);\n const dataType = this.parent.dataType;\n const shaderDataType = getShaderType(dataType);\n builder.addFragmentCode(\n defineLerpShaderFunction(builder, \"ng_colorLegendLerp\", dataType),\n );\n builder.addFragmentCode(`\nvoid emit(vec4 v) {\n v4f_fragData0 = v;\n}\n${shaderDataType} getDataValue() {\n return ng_colorLegendLerp(vLinearPosition);\n}\n${shaderDataType} getDataValue(int dummyChannel) {\n return getDataValue();\n}\n${shaderDataType} getInterpolatedDataValue() {\n return getDataValue();\n}\n${shaderDataType} getInterpolatedDataValue(int dummyChannel) {\n return getDataValue();\n}\n`);\n shaderOptions.defineShader(builder, parameters, extraParameters);\n },\n },\n );\n }\n\n private shaderGetter: ParameterizedEmitterDependentShaderGetter;\n\n private cornersBuffer = getSquareCornersBuffer(this.gl, -1, -1, 1, 1);\n\n drawIndirect() {\n const shaderResult = this.shaderGetter(dummyColorLegendShaderModule);\n const { shader } = shaderResult;\n if (shader === null) return;\n this.setGLLogicalViewport();\n const { gl } = this;\n gl.clearColor(0.0, 0.0, 0.0, 0.0);\n gl.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT);\n shader.bind();\n this.shaderOptions.initializeShader(shaderResult);\n gl.enable(WebGL2RenderingContext.BLEND);\n const {\n trackable: {\n value: { window },\n },\n dataType,\n } = this.parent;\n enableLerpShaderFunction(\n shader,\n \"ng_colorLegendLerp\",\n this.parent.dataType,\n window,\n );\n const legendOffset = getIntervalBoundsEffectiveOffset(dataType, window);\n gl.uniform1f(\n shader.uniform(\"uLegendOffset\"),\n Number.isFinite(legendOffset) ? legendOffset : 0,\n );\n gl.blendFunc(\n WebGL2RenderingContext.SRC_ALPHA,\n WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA,\n );\n gl.disable(WebGL2RenderingContext.DEPTH_TEST);\n gl.disable(WebGL2RenderingContext.STENCIL_TEST);\n const aVertexPosition = shader.attribute(\"aVertexPosition\");\n this.cornersBuffer.bindToVertexAttrib(\n aVertexPosition,\n /*componentsPerVertexAttribute=*/ 2,\n /*attributeType=*/ WebGL2RenderingContext.FLOAT,\n );\n gl.drawArrays(WebGL2RenderingContext.TRIANGLE_FAN, 0, 4);\n gl.disableVertexAttribArray(aVertexPosition);\n }\n\n isReady() {\n return true;\n }\n}\n\nfunction createRangeBoundInput(\n boundType: \"range\" | \"window\",\n endpoint: number,\n) {\n const e = document.createElement(\"input\");\n e.addEventListener(\"focus\", () => {\n e.select();\n });\n e.classList.add(\"neuroglancer-invlerp-widget-bound\");\n e.classList.add(`neuroglancer-invlerp-widget-${boundType}-bound`);\n e.type = \"text\";\n e.spellcheck = false;\n e.autocomplete = \"off\";\n e.title =\n boundType === \"range\"\n ? `Data value that maps to ${endpoint}`\n : `${endpoint === 0 ? \"Lower\" : \"Upper\"} bound for distribution`;\n return e;\n}\n\nfunction createRangeBoundInputs(\n boundType: \"range\" | \"window\",\n dataType: DataType,\n model: WatchableValueInterface,\n) {\n const container = document.createElement(\"div\");\n container.classList.add(\"neuroglancer-invlerp-widget-bounds\");\n container.classList.add(`neuroglancer-invlerp-widget-${boundType}-bounds`);\n const inputs = [\n createRangeBoundInput(boundType, 0),\n createRangeBoundInput(boundType, 1),\n ] as [HTMLInputElement, HTMLInputElement];\n for (let endpointIndex = 0; endpointIndex < 2; ++endpointIndex) {\n const input = inputs[endpointIndex];\n input.addEventListener(\"input\", () => {\n updateInputBoundWidth(input);\n });\n input.addEventListener(\"change\", () => {\n const existingBounds = model.value;\n const existingInterval = existingBounds[boundType];\n try {\n const value = parseDataTypeValue(dataType, input.value);\n model.value = getUpdatedRangeAndWindowParameters(\n existingBounds,\n boundType,\n endpointIndex,\n value,\n /*fitRangeInWindow=*/ true,\n );\n } catch {\n updateInputBoundValue(input, existingInterval[endpointIndex]);\n }\n });\n }\n let spacers: [HTMLElement, HTMLElement, HTMLElement] | undefined;\n container.appendChild(inputs[0]);\n container.appendChild(inputs[1]);\n if (boundType === \"range\") {\n spacers = [\n document.createElement(\"div\"),\n document.createElement(\"div\"),\n document.createElement(\"div\"),\n ];\n spacers[1].classList.add(\"neuroglancer-invlerp-widget-range-spacer\");\n container.insertBefore(spacers[0], inputs[0]);\n container.insertBefore(spacers[1], inputs[1]);\n container.appendChild(spacers[2]);\n }\n return { container, inputs, spacers };\n}\n\nexport function updateInputBoundWidth(inputElement: HTMLInputElement) {\n updateInputFieldWidth(\n inputElement,\n Math.max(1, inputElement.value.length + 0.1),\n );\n}\n\nexport function updateInputBoundValue(\n inputElement: HTMLInputElement,\n bound: number | Uint64,\n) {\n let boundString: string;\n if (bound instanceof Uint64 || Number.isInteger(bound)) {\n boundString = bound.toString();\n } else {\n boundString = bound.toPrecision(6);\n }\n inputElement.value = boundString;\n updateInputBoundWidth(inputElement);\n}\n\nexport function invertInvlerpRange(\n trackable: WatchableValueInterface,\n) {\n const bounds = trackable.value;\n const { range } = bounds;\n trackable.value = {\n ...bounds,\n range: [range[1], range[0]] as DataTypeInterval,\n };\n}\n\nexport function adjustInvlerpContrast(\n dataType: DataType,\n trackable: WatchableValueInterface,\n scaleFactor: number,\n) {\n const bounds = trackable.value;\n const newLower = computeLerp(bounds.range, dataType, 0.5 - scaleFactor / 2);\n const newUpper = computeLerp(bounds.range, dataType, 0.5 + scaleFactor / 2);\n trackable.value = {\n ...bounds,\n range: [newLower, newUpper] as DataTypeInterval,\n };\n}\n\nexport function adjustInvlerpBrightnessContrast(\n dataType: DataType,\n trackable: WatchableValueInterface,\n baseRange: DataTypeInterval,\n brightnessAmount: number,\n contrastAmount: number,\n) {\n const scaleFactor = Math.exp(contrastAmount);\n const bounds = trackable.value;\n const newLower = computeLerp(\n baseRange,\n dataType,\n 0.5 - scaleFactor / 2 + brightnessAmount,\n );\n const newUpper = computeLerp(\n baseRange,\n dataType,\n 0.5 + scaleFactor / 2 + brightnessAmount,\n );\n trackable.value = {\n ...bounds,\n range: [newLower, newUpper] as DataTypeInterval,\n };\n}\n\nexport class InvlerpWidget extends Tab {\n cdfPanel = this.registerDisposer(new CdfPanel(this));\n boundElements = {\n range: createRangeBoundInputs(\"range\", this.dataType, this.trackable),\n window: createRangeBoundInputs(\"window\", this.dataType, this.trackable),\n };\n invertArrows: HTMLElement[];\n get texture() {\n return this.histogramSpecifications.getFramebuffers(this.display.gl)[\n this.histogramIndex\n ].colorBuffers[0].texture;\n }\n private invertRange() {\n invertInvlerpRange(this.trackable);\n }\n constructor(\n visibility: WatchableVisibilityPriority,\n public display: DisplayContext,\n public dataType: DataType,\n public trackable: WatchableValueInterface,\n public histogramSpecifications: HistogramSpecifications,\n public histogramIndex: number,\n public legendShaderOptions: LegendShaderOptions | undefined,\n ) {\n super(visibility);\n this.registerDisposer(\n histogramSpecifications.visibility.add(this.visibility),\n );\n const { element, boundElements } = this;\n if (legendShaderOptions !== undefined) {\n const legendPanel = this.registerDisposer(new ColorLegendPanel(this));\n element.appendChild(legendPanel.element);\n }\n const makeArrow = (svg: string) => {\n const icon = makeIcon({\n svg,\n title: \"Invert range\",\n onClick: () => {\n this.invertRange();\n },\n });\n boundElements.range.spacers![1].appendChild(icon);\n return icon;\n };\n this.invertArrows = [makeArrow(svg_arrowRight), makeArrow(svg_arrowLeft)];\n element.appendChild(boundElements.range.container);\n element.appendChild(this.cdfPanel.element);\n element.classList.add(\"neuroglancer-invlerp-widget\");\n element.appendChild(boundElements.window.container);\n this.updateView();\n this.registerDisposer(\n trackable.changed.add(\n this.registerCancellable(\n animationFrameDebounce(() => this.updateView()),\n ),\n ),\n );\n }\n\n updateView() {\n const { boundElements } = this;\n const {\n trackable: { value: bounds },\n dataType,\n } = this;\n for (let i = 0; i < 2; ++i) {\n updateInputBoundValue(boundElements.range.inputs[i], bounds.range[i]);\n updateInputBoundValue(boundElements.window.inputs[i], bounds.window[i]);\n }\n const reversed = dataTypeCompare(bounds.range[0], bounds.range[1]) > 0;\n boundElements.range.container.style.flexDirection = !reversed\n ? \"row\"\n : \"row-reverse\";\n const clampedRange = getClampedInterval(bounds.window, bounds.range);\n const spacers = boundElements.range.spacers!;\n const effectiveFraction = getIntervalBoundsEffectiveFraction(\n dataType,\n bounds.window,\n );\n const leftOffset =\n computeInvlerp(bounds.window, clampedRange[reversed ? 1 : 0]) *\n effectiveFraction;\n const rightOffset =\n computeInvlerp(bounds.window, clampedRange[reversed ? 0 : 1]) *\n effectiveFraction +\n (1 - effectiveFraction);\n spacers[reversed ? 2 : 0].style.width = `${leftOffset * 100}%`;\n spacers[reversed ? 0 : 2].style.width = `${(1 - rightOffset) * 100}%`;\n const { invertArrows } = this;\n invertArrows[reversed ? 1 : 0].style.display = \"\";\n invertArrows[reversed ? 0 : 1].style.display = \"none\";\n }\n}\n\nexport class VariableDataTypeInvlerpWidget extends Tab {\n invlerpWidget: Owned;\n constructor(\n visibility: WatchableVisibilityPriority,\n public display: DisplayContext,\n public watchableDataType: WatchableValueInterface,\n public trackable: WatchableValueInterface,\n public histogramSpecifications: HistogramSpecifications,\n public histogramIndex: number,\n public legendShaderOptions: LegendShaderOptions | undefined,\n ) {\n super(visibility);\n this.invlerpWidget = this.makeInvlerpWidget();\n this.registerDisposer(\n watchableDataType.changed.add(() => {\n removeChildren(this.element);\n this.invlerpWidget.dispose();\n this.invlerpWidget = this.makeInvlerpWidget();\n }),\n );\n }\n\n get dataType() {\n return this.watchableDataType.value;\n }\n\n disposed() {\n this.invlerpWidget.dispose();\n super.disposed();\n }\n\n private makeInvlerpWidget() {\n const { dataType } = this;\n const widget = new InvlerpWidget(\n this.visibility,\n this.display,\n dataType,\n this.trackable,\n this.histogramSpecifications,\n this.histogramIndex,\n this.legendShaderOptions,\n );\n this.element.appendChild(widget.element);\n return widget;\n }\n}\n\nconst TOOL_INPUT_EVENT_MAP = EventActionMap.fromObject({\n \"at:shift+wheel\": { action: \"adjust-contrast-via-wheel\" },\n \"at:shift+mousedown0\": { action: \"adjust-via-drag\" },\n \"at:shift+mousedown2\": { action: \"invert-range\" },\n});\n\nexport function activateInvlerpTool(\n activation: ToolActivation,\n control: InvlerpWidget | VariableDataTypeInvlerpWidget,\n) {\n activation.bindInputEventMap(TOOL_INPUT_EVENT_MAP);\n activation.bindAction(\"adjust-contrast-via-wheel\", (event) => {\n event.stopPropagation();\n const zoomAmount = getWheelZoomAmount(event.detail);\n adjustInvlerpContrast(control.dataType, control.trackable, zoomAmount);\n });\n activation.bindAction(\"adjust-via-drag\", (event) => {\n event.stopPropagation();\n let baseScreenX = event.detail.screenX;\n let baseScreenY = event.detail.screenY;\n let baseRange = control.trackable.value.range;\n let prevRange = baseRange;\n let prevScreenX = baseScreenX;\n let prevScreenY = baseScreenY;\n startRelativeMouseDrag(event.detail, (newEvent) => {\n const curRange = control.trackable.value.range;\n const curScreenX = newEvent.screenX;\n const curScreenY = newEvent.screenY;\n if (!dataTypeIntervalEqual(control.dataType, curRange, prevRange)) {\n baseRange = curRange;\n baseScreenX = prevScreenX;\n baseScreenY = prevScreenY;\n }\n adjustInvlerpBrightnessContrast(\n control.dataType,\n control.trackable,\n baseRange,\n ((curScreenY - baseScreenY) * 2) / screen.height,\n ((curScreenX - baseScreenX) * 4) / screen.width,\n );\n prevRange = control.trackable.value.range;\n prevScreenX = curScreenX;\n prevScreenY = curScreenY;\n });\n });\n activation.bindAction(\"invert-range\", (event) => {\n event.stopPropagation();\n invertInvlerpRange(control.trackable);\n });\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport svg_close from \"ikonate/icons/close.svg?raw\";\nimport type { MakeIconOptions } from \"#src/widget/icon.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\n\nexport function makeCloseButton(options: MakeIconOptions = {}) {\n return makeIcon({ svg: svg_close, ...options });\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/status.css\";\n\nimport { makeCloseButton } from \"#src/widget/close_button.js\";\n\nlet statusContainer: HTMLElement | null = null;\nlet modalStatusContainer: HTMLElement | null = null;\n\nexport const DEFAULT_STATUS_DELAY = 200;\n\nexport type Delay = boolean | number;\n\nexport class StatusMessage {\n element: HTMLElement;\n modalElementWrapper: HTMLElement | undefined;\n private timer: number | null;\n constructor(delay: Delay = false, modal = false) {\n if (statusContainer === null) {\n statusContainer = document.createElement(\"ul\");\n statusContainer.id = \"statusContainer\";\n statusContainer.tabIndex = -1;\n const el: HTMLElement | null = document.getElementById(\n \"neuroglancer-container\",\n );\n if (el) {\n el.appendChild(statusContainer);\n } else {\n document.body.appendChild(statusContainer);\n }\n }\n if (modal && modalStatusContainer === null) {\n modalStatusContainer = document.createElement(\"ul\");\n modalStatusContainer.id = \"statusContainerModal\";\n const el: HTMLElement | null = document.getElementById(\n \"neuroglancer-container\",\n );\n if (el) {\n el.appendChild(modalStatusContainer);\n } else {\n document.body.appendChild(modalStatusContainer);\n }\n }\n const element = document.createElement(\"li\");\n this.element = element;\n if (delay === true) {\n delay = DEFAULT_STATUS_DELAY;\n }\n if (delay !== false) {\n this.setVisible(false);\n this.timer = window.setTimeout(this.setVisible.bind(this, true), delay);\n } else {\n this.timer = null;\n }\n if (modal) {\n const modalElementWrapper = document.createElement(\"div\");\n const dismissModalElement = makeCloseButton({\n title: \"Dismiss\",\n onClick: () => {\n this.dismissModal();\n },\n });\n dismissModalElement.classList.add(\"dismiss-modal\");\n dismissModalElement.addEventListener(\"click\", () => this.dismissModal());\n modalElementWrapper.appendChild(dismissModalElement);\n modalElementWrapper.appendChild(element);\n this.modalElementWrapper = modalElementWrapper;\n modalStatusContainer!.appendChild(modalElementWrapper);\n } else {\n statusContainer.appendChild(element);\n }\n }\n dispose() {\n if (this.modalElementWrapper) {\n modalStatusContainer!.removeChild(this.modalElementWrapper);\n } else {\n statusContainer!.removeChild(this.element);\n }\n this.element = undefined;\n if (this.timer !== null) {\n clearTimeout(this.timer);\n }\n }\n dismissModal() {\n if (this.modalElementWrapper) {\n modalStatusContainer!.removeChild(this.modalElementWrapper);\n this.modalElementWrapper = undefined;\n statusContainer!.appendChild(this.element);\n }\n }\n setText(text: string, makeVisible?: boolean) {\n this.element.textContent = text;\n if (makeVisible) {\n this.setVisible(true);\n }\n }\n setHTML(text: string, makeVisible?: boolean) {\n this.element.innerHTML = text;\n if (makeVisible) {\n this.setVisible(true);\n }\n }\n setVisible(value: boolean) {\n if (this.timer !== null) {\n clearTimeout(this.timer);\n this.timer = null;\n }\n this.element.style.display = value ? \"block\" : \"none\";\n }\n\n static forPromise(\n promise: Promise,\n options: { initialMessage: string; delay?: Delay; errorPrefix: string },\n ): Promise {\n const status = new StatusMessage(options.delay);\n status.setText(options.initialMessage);\n const dispose = status.dispose.bind(status);\n promise.then(dispose, (reason) => {\n let msg: string;\n if (reason instanceof Error) {\n msg = reason.message;\n } else {\n msg = \"\" + reason;\n }\n const { errorPrefix = \"\" } = options;\n status.setErrorMessage(errorPrefix + msg);\n status.setVisible(true);\n });\n return promise;\n }\n\n setErrorMessage(message: string) {\n this.element.textContent = message + \" \";\n const button = document.createElement(\"button\");\n button.textContent = \"Dismiss\";\n button.addEventListener(\"click\", () => {\n this.dispose();\n });\n this.element.appendChild(button);\n }\n\n static showMessage(message: string): StatusMessage {\n const msg = new StatusMessage();\n msg.element.textContent = message;\n msg.setVisible(true);\n return msg;\n }\n\n static showTemporaryMessage(\n message: string,\n closeAfter = 2000,\n ): StatusMessage {\n const msg = StatusMessage.showMessage(message);\n window.setTimeout(() => msg.dispose(), closeAfter);\n return msg;\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Support for defining user-selectable tools.\n */\n\nimport \"#src/ui/tool.css\";\n\nimport { debounce } from \"lodash-es\";\nimport type { MouseSelectionState, UserLayer } from \"#src/layer/index.js\";\nimport { StatusMessage } from \"#src/status.js\";\nimport type { TrackableValueInterface } from \"#src/trackable_value.js\";\nimport { animationFrameDebounce } from \"#src/util/animation_frame_debounce.js\";\nimport type { Borrowed, Owned } from \"#src/util/disposable.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type {\n ActionEvent,\n EventActionMap,\n} from \"#src/util/event_action_map.js\";\nimport { registerActionListener } from \"#src/util/event_action_map.js\";\nimport {\n verifyObject,\n verifyObjectProperty,\n verifyString,\n} from \"#src/util/json.js\";\nimport type { AnyConstructor } from \"#src/util/mixin.js\";\nimport { Signal } from \"#src/util/signal.js\";\n\nconst TOOL_KEY_PATTERN = /^[A-Z]$/;\n\nexport type InputEventMapBinder = (\n eventActionMap: EventActionMap,\n context: RefCounted,\n) => void;\n\nexport class ToolActivation extends RefCounted {\n constructor(\n public tool: ToolType,\n public inputEventMapBinder: InputEventMapBinder,\n ) {\n super();\n }\n bindAction(\n action: string,\n listener: (event: ActionEvent) => void,\n ) {\n this.registerDisposer(registerActionListener(window, action, listener));\n }\n bindInputEventMap(inputEventMap: EventActionMap) {\n this.inputEventMapBinder(inputEventMap, this);\n }\n cancel() {\n const { globalBinder } = this.tool;\n if (this === globalBinder.activeTool_) {\n globalBinder.deactivate_();\n }\n }\n}\n\nexport abstract class Tool extends RefCounted {\n changed = new Signal();\n keyBinding: string | undefined = undefined;\n\n get context() {\n return this.localBinder.context;\n }\n\n get globalBinder() {\n return this.localBinder.globalBinder;\n }\n\n constructor(\n public readonly localBinder: LocalToolBinder,\n public toggle = false,\n ) {\n super();\n }\n abstract activate(activation: ToolActivation): void;\n abstract toJSON(): any;\n abstract description: string;\n unbind() {\n const { keyBinding } = this;\n if (keyBinding !== undefined) {\n this.localBinder.set(keyBinding, undefined);\n }\n }\n}\n\nexport abstract class LayerTool<\n LayerType extends UserLayer = UserLayer,\n> extends Tool {\n constructor(\n public layer: LayerType,\n toggle = false,\n ) {\n super(layer.toolBinder, toggle);\n }\n get mouseState() {\n return this.layer.manager.root.layerSelectedValues.mouseState;\n }\n}\n\nexport abstract class LegacyTool<\n LayerType extends UserLayer = UserLayer,\n> extends RefCounted {\n changed = new Signal();\n constructor(public layer: LayerType) {\n super();\n }\n get context() {\n return this.layer;\n }\n get mouseState() {\n return this.layer.manager.root.layerSelectedValues.mouseState;\n }\n abstract trigger(mouseState: MouseSelectionState): void;\n abstract toJSON(): any;\n deactivate(): void {}\n abstract description: string;\n unbind() {\n const { layer } = this;\n if (layer.tool.value === this) {\n layer.tool.value = undefined;\n }\n }\n}\n\nexport function restoreTool(\n context: Context,\n obj: unknown,\n) {\n if (obj === undefined) {\n return undefined;\n }\n if (typeof obj === \"string\") {\n obj = { type: obj };\n }\n verifyObject(obj);\n const type = verifyObjectProperty(obj, \"type\", verifyString);\n\n let prototype = context;\n let getter: ToolGetter | undefined;\n while (true) {\n prototype = Object.getPrototypeOf(prototype);\n if (prototype === null) {\n throw new Error(`Invalid tool type: ${JSON.stringify(obj)}.`);\n }\n getter = toolsForPrototype.get(prototype)?.get(type);\n if (getter !== undefined) break;\n }\n return getter(context, obj);\n}\n\nexport function restoreLegacyTool(layer: UserLayer, obj: any) {\n if (obj === undefined) {\n return undefined;\n }\n if (typeof obj === \"string\") {\n obj = { type: obj };\n }\n verifyObject(obj);\n const type = verifyObjectProperty(obj, \"type\", verifyString);\n const getter = legacyTools.get(type);\n if (getter === undefined) {\n throw new Error(`Invalid tool type: ${JSON.stringify(obj)}.`);\n }\n return getter(layer, obj);\n}\n\nexport type ToolGetter = (\n context: Context,\n options: any,\n) => Owned | undefined;\n\nexport type LegacyToolGetter = (\n layer: LayerType,\n options: any,\n) => Owned | undefined;\n\nconst legacyTools = new Map();\nconst toolsForPrototype = new Map>();\n\nexport function registerLegacyTool(type: string, getter: LegacyToolGetter) {\n legacyTools.set(type, getter);\n}\n\nexport function registerTool(\n contextType: AnyConstructor,\n type: string,\n getter: ToolGetter,\n) {\n const { prototype } = contextType;\n let tools = toolsForPrototype.get(prototype);\n if (tools === undefined) {\n tools = new Map();\n toolsForPrototype.set(prototype, tools);\n }\n tools.set(type, getter);\n}\n\nexport function unregisterTool(\n contextType: AnyConstructor,\n type: string,\n) {\n const { prototype } = contextType;\n const tools = toolsForPrototype.get(prototype);\n if (tools) {\n tools.delete(type);\n }\n}\n\nexport class SelectedLegacyTool\n extends RefCounted\n implements TrackableValueInterface\n{\n changed = new Signal();\n private value_: Owned | undefined;\n\n get value() {\n return this.value_;\n }\n\n set value(newValue: Owned | undefined) {\n if (newValue === this.value_) return;\n this.unregister();\n if (newValue !== undefined) {\n newValue.changed.add(this.changed.dispatch);\n this.value_ = newValue;\n }\n this.changed.dispatch();\n }\n\n private unregister() {\n const existingValue = this.value_;\n if (existingValue !== undefined) {\n existingValue.changed.remove(this.changed.dispatch);\n existingValue.dispose();\n this.value_ = undefined;\n }\n }\n\n disposed() {\n this.unregister();\n super.disposed();\n }\n\n restoreState(obj: unknown) {\n this.value = restoreLegacyTool(this.layer, obj);\n }\n\n reset() {\n this.value = undefined;\n }\n\n toJSON() {\n const value = this.value_;\n if (value === undefined) return undefined;\n return value.toJSON();\n }\n constructor(public layer: UserLayer) {\n super();\n }\n}\n\nexport class GlobalToolBinder extends RefCounted {\n bindings = new Map>();\n changed = new Signal();\n activeTool_: Owned | undefined; // For internal use only- should only be called by ToolBinder and ToolActivation.cancel()\n private queuedTool: Tool | undefined;\n private debounceDeactivate = this.registerCancellable(\n debounce(() => {\n this.deactivate_();\n this.reactivateQueuedTool();\n }, 100),\n );\n\n constructor(private inputEventMapBinder: InputEventMapBinder) {\n super();\n }\n\n get(key: string): Borrowed | undefined {\n return this.bindings.get(key);\n }\n\n set(key: string, tool: Owned | undefined) {\n const { bindings } = this;\n const existingTool = bindings.get(key);\n if (existingTool !== undefined) {\n existingTool.keyBinding = undefined;\n bindings.delete(key);\n const localToolBinder = existingTool.localBinder;\n localToolBinder.bindings.delete(key);\n localToolBinder.jsonToKey.delete(JSON.stringify(existingTool.toJSON()));\n this.destroyTool(existingTool);\n localToolBinder.changed.dispatch();\n }\n if (tool !== undefined) {\n const localToolBinder = tool.localBinder;\n const json = JSON.stringify(tool.toJSON());\n const existingKey = localToolBinder.jsonToKey.get(json);\n if (existingKey !== undefined) {\n const existingTool = localToolBinder.bindings.get(existingKey)!;\n existingTool.keyBinding = undefined;\n bindings.delete(existingKey);\n localToolBinder.bindings.delete(existingKey);\n localToolBinder.jsonToKey.delete(json);\n this.destroyTool(existingTool);\n }\n localToolBinder.bindings.set(key, tool);\n tool.keyBinding = key;\n localToolBinder.jsonToKey.set(json, key);\n bindings.set(key, tool);\n localToolBinder.changed.dispatch();\n }\n this.changed.dispatch();\n }\n\n activate(key: string, tool?: Tool): Borrowed | undefined {\n tool = tool || this.get(key);\n if (tool === undefined) {\n this.deactivate_();\n return;\n }\n this.debounceDeactivate.cancel();\n const activeTool = this.activeTool_;\n if (tool.toJSON() === activeTool?.tool.toJSON()) {\n if (tool.toggle) {\n this.deactivate_();\n }\n return;\n }\n if (activeTool !== undefined) {\n if (activeTool.tool.toggle && !tool.toggle) {\n this.queuedTool = activeTool.tool;\n }\n this.deactivate_();\n }\n const activation = new ToolActivation(tool, this.inputEventMapBinder);\n this.activeTool_ = activation;\n if (!tool.toggle) {\n const expectedCode = `Key${key}`;\n activation.registerEventListener(\n window,\n \"keydown\",\n (event: KeyboardEvent) => {\n // Prevent other key input while tool is activated. This\n // prevents `shift+key` from being interpreted as text input\n // if an input element becomes focused.\n event.stopPropagation();\n event.preventDefault();\n },\n );\n activation.registerEventListener(\n window,\n \"keyup\",\n (event: KeyboardEvent) => {\n if (event.code === expectedCode) {\n this.debounceDeactivate();\n }\n },\n );\n activation.registerEventListener(window, \"blur\", () => {\n this.debounceDeactivate();\n });\n }\n tool.activate(activation);\n return tool;\n }\n\n private reactivateQueuedTool() {\n if (this.queuedTool) {\n const activation = new ToolActivation(\n this.queuedTool,\n this.inputEventMapBinder,\n );\n this.activeTool_ = activation;\n this.queuedTool.activate(activation);\n this.queuedTool = undefined;\n }\n }\n\n destroyTool(tool: Owned) {\n if (this.queuedTool === tool) {\n this.queuedTool = undefined;\n }\n if (this.activeTool_?.tool === tool) {\n this.deactivate_();\n }\n tool.dispose();\n }\n\n disposed() {\n this.deactivate_();\n super.disposed();\n }\n\n deactivate_() {\n // For internal use only- should only be called by ToolBinder and ToolActivation.cancel()\n this.debounceDeactivate.cancel();\n const activation = this.activeTool_;\n if (activation === undefined) return;\n this.activeTool_ = undefined;\n activation.dispose();\n }\n}\n\nexport class LocalToolBinder<\n Context extends object = object,\n> extends RefCounted {\n // Maps the the tool key (i.e. \"A\", \"B\", ...) to the bound tool.\n bindings = new Map>();\n // Maps the serialized json representation of the tool to the tool key.\n jsonToKey = new Map();\n changed = new Signal();\n\n constructor(\n public context: Context,\n public globalBinder: GlobalToolBinder,\n ) {\n super();\n }\n\n disposed() {\n this.clear();\n super.disposed();\n }\n\n get(key: string): Borrowed | undefined {\n return this.bindings.get(key);\n }\n\n set(key: string, tool: Owned | undefined) {\n this.globalBinder.set(key, tool);\n }\n\n setJson(key: string, toolJson: any) {\n const tool = restoreTool(this.context, toolJson);\n if (tool === undefined) return;\n this.set(key, tool);\n }\n\n removeJsonString(toolJsonString: string) {\n const key = this.jsonToKey.get(toolJsonString);\n if (key === undefined) return;\n this.set(key, undefined);\n }\n\n toJSON(): any {\n const { bindings } = this;\n if (bindings.size === 0) return undefined;\n const obj: any = {};\n for (const [key, value] of bindings) {\n obj[key] = value.toJSON();\n }\n return obj;\n }\n\n deleteTool(key: string) {\n const { globalBinder, bindings, jsonToKey } = this;\n const existingTool = bindings.get(key);\n if (existingTool) {\n bindings.delete(key);\n globalBinder.bindings.delete(key);\n jsonToKey.delete(JSON.stringify(existingTool.toJSON()));\n globalBinder.destroyTool(existingTool);\n globalBinder.changed.dispatch();\n this.changed.dispatch();\n }\n }\n\n clear() {\n const { globalBinder, bindings } = this;\n if (bindings.size !== 0) {\n for (const [key, tool] of bindings) {\n tool.keyBinding = undefined;\n globalBinder.bindings.delete(key);\n globalBinder.destroyTool(tool);\n }\n bindings.clear();\n this.jsonToKey.clear();\n globalBinder.changed.dispatch();\n this.changed.dispatch();\n }\n }\n\n reset() {\n this.clear();\n }\n\n restoreState(obj: any) {\n if (obj === undefined) return;\n verifyObject(obj);\n for (const [key, value] of Object.entries(obj)) {\n if (!key.match(TOOL_KEY_PATTERN)) {\n throw new Error(`Invalid tool key: ${JSON.stringify(key)}`);\n }\n const tool = restoreTool(this.context, value);\n if (tool === undefined) return;\n this.set(key, tool);\n }\n }\n}\n\nexport class ToolBindingWidget extends RefCounted {\n element = document.createElement(\"div\");\n private toolJsonString = JSON.stringify(this.toolJson);\n constructor(\n public localBinder: LocalToolBinder,\n public toolJson: any,\n ) {\n super();\n const { element } = this;\n element.classList.add(\"neuroglancer-tool-key-binding\");\n this.registerDisposer(\n localBinder.changed.add(\n this.registerCancellable(\n animationFrameDebounce(() => this.updateView()),\n ),\n ),\n );\n this.updateView();\n element.title = \"click → bind key, dbclick → unbind\";\n element.addEventListener(\"dblclick\", () => {\n this.localBinder.removeJsonString(this.toolJsonString);\n });\n addToolKeyBindHandlers(this, element, (key) =>\n this.localBinder.setJson(key, this.toolJson),\n );\n }\n\n private updateView() {\n const { localBinder } = this;\n const key = localBinder.jsonToKey.get(this.toolJsonString);\n this.element.textContent = key ?? \" \";\n }\n}\n\nexport function addToolKeyBindHandlers(\n context: RefCounted,\n element: HTMLElement,\n bindKey: (key: string) => void,\n) {\n let mousedownContext: RefCounted | undefined;\n element.addEventListener(\"mousedown\", (event) => {\n if (event.button !== 0 || mousedownContext !== undefined) return;\n event.preventDefault();\n event.stopPropagation();\n mousedownContext = new RefCounted();\n context.registerDisposer(mousedownContext);\n const message = mousedownContext.registerDisposer(new StatusMessage(false));\n message.setText(\"Press A-Z to bind key\");\n mousedownContext.registerEventListener(\n window,\n \"keydown\",\n (event: KeyboardEvent) => {\n const { code } = event;\n const m = code.match(/^Key([A-Z])$/);\n if (m === null) return;\n event.stopPropagation();\n event.preventDefault();\n const key = m[1];\n bindKey(key);\n },\n { capture: true },\n );\n mousedownContext.registerEventListener(\n window,\n \"mouseup\",\n (event: MouseEvent) => {\n if (event.button !== 0 || mousedownContext === undefined) return;\n event.preventDefault();\n event.stopPropagation();\n context.unregisterDisposer(mousedownContext);\n mousedownContext.dispose();\n mousedownContext = undefined;\n },\n );\n });\n element.addEventListener(\"click\", (event) => {\n event.preventDefault();\n event.stopPropagation();\n });\n}\n\nexport function makeToolButton(\n context: RefCounted,\n localBinder: LocalToolBinder,\n options: { toolJson: any; label?: string; title?: string },\n) {\n const element = document.createElement(\"div\");\n element.classList.add(\"neuroglancer-tool-button\");\n element.appendChild(\n context.registerDisposer(\n new ToolBindingWidget(localBinder, options.toolJson),\n ).element,\n );\n const labelElement = document.createElement(\"div\");\n labelElement.classList.add(\"neuroglancer-tool-button-label\");\n const labelText = options.label;\n if (labelText !== undefined) {\n labelElement.textContent = labelText;\n }\n if (options.title) {\n labelElement.title = options.title;\n }\n element.appendChild(labelElement);\n return element;\n}\n\nexport function makeToolActivationStatusMessage(activation: ToolActivation) {\n const message = activation.registerDisposer(new StatusMessage(false));\n message.element.classList.add(\"neuroglancer-tool-status\");\n const content = document.createElement(\"div\");\n content.classList.add(\"neuroglancer-tool-status-content\");\n message.element.appendChild(content);\n const { inputEventMapBinder } = activation;\n activation.inputEventMapBinder = (\n inputEventMap: EventActionMap,\n context: RefCounted,\n ) => {\n const bindingHelp = document.createElement(\"div\");\n bindingHelp.textContent = inputEventMap.describe();\n bindingHelp.classList.add(\"neuroglancer-tool-status-bindings\");\n message.element.appendChild(bindingHelp);\n inputEventMapBinder(inputEventMap, context);\n };\n return { message, content };\n}\n\nexport function makeToolActivationStatusMessageWithHeader(\n activation: ToolActivation,\n) {\n const { message, content } = makeToolActivationStatusMessage(activation);\n const header = document.createElement(\"div\");\n header.classList.add(\"neuroglancer-tool-status-header\");\n const headerContainer = document.createElement(\"div\");\n headerContainer.classList.add(\"neuroglancer-tool-status-header-container\");\n headerContainer.appendChild(header);\n content.appendChild(headerContainer);\n const body = document.createElement(\"div\");\n body.classList.add(\"neuroglancer-tool-status-body\");\n content.appendChild(body);\n return { message, body, header };\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { registerEventListener } from \"#src/util/disposable.js\";\n\nexport function setClipboard(data: string, format = \"text/plain\") {\n let success = false;\n const cleanup = registerEventListener(\n document,\n \"copy\",\n (event: ClipboardEvent) => {\n const { clipboardData } = event;\n if (clipboardData !== null) {\n clipboardData.setData(format, data);\n success = true;\n }\n event.stopPropagation();\n event.preventDefault();\n },\n true,\n );\n try {\n document.execCommand(\"copy\");\n } finally {\n cleanup();\n }\n return success;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Facility for triggering named actions in response to keyboard events.\n */\n\n// This is based on goog/ui/keyboardshortcuthandler.js in the Google Closure library.\n\nimport { WatchableValue } from \"#src/trackable_value.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type {\n ActionEvent,\n EventActionMapInterface,\n} from \"#src/util/event_action_map.js\";\nimport {\n dispatchEventWithModifiers,\n EventActionMap,\n registerActionListener,\n getEventModifierMask,\n} from \"#src/util/event_action_map.js\";\n\nexport const globalModifiers = new WatchableValue(0);\nwindow.addEventListener(\"keydown\", (event) => {\n globalModifiers.value = getEventModifierMask(event);\n});\nwindow.addEventListener(\"keyup\", (event) => {\n globalModifiers.value = getEventModifierMask(event);\n});\n\nconst globalKeys = new Set([\n \"f1\",\n \"f2\",\n \"f3\",\n \"f4\",\n \"f5\",\n \"f6\",\n \"f7\",\n \"f8\",\n \"f9\",\n \"f10\",\n \"f11\",\n \"f12\",\n \"escape\",\n \"pause\",\n]);\nconst DEFAULT_TEXT_INPUTS = new Set([\n \"color\",\n \"date\",\n \"datetime\",\n \"datetime-local\",\n \"email\",\n \"month\",\n \"number\",\n \"password\",\n \"search\",\n \"tel\",\n \"text\",\n \"time\",\n \"url\",\n \"week\",\n]);\n\nexport class KeyboardEventBinder<\n EventMap extends EventActionMapInterface,\n> extends RefCounted {\n modifierShortcutsAreGlobal = true;\n allShortcutsAreGlobal = false;\n allowSpaceKeyOnButtons = false;\n shouldIgnore: ((event: KeyboardEvent) => boolean) | undefined = undefined;\n constructor(\n public target: EventTarget,\n public eventMap: EventMap,\n ) {\n super();\n this.registerEventListener(\n target,\n \"keydown\",\n this.handleKeyDown.bind(this),\n /*useCapture=*/ false,\n );\n }\n\n private shouldIgnoreEvent(key: string, event: KeyboardEvent) {\n if (this.shouldIgnore?.(event)) return true;\n const el = event.target;\n const { tagName } = el;\n if (el === this.target) {\n // If the event is directly on the target element, we never ignore it.\n return false;\n }\n const isFormElement =\n tagName === \"TEXTAREA\" ||\n tagName === \"INPUT\" ||\n tagName === \"BUTTON\" ||\n tagName === \"SELECT\";\n\n const isContentEditable =\n !isFormElement &&\n (el.isContentEditable ||\n (el.ownerDocument && el.ownerDocument.designMode === \"on\"));\n\n if (!isFormElement && !isContentEditable) {\n return false;\n }\n // Always allow keys registered as global to be used (typically Esc, the\n // F-keys and other keys that are not typically used to manipulate text).\n if (this.allShortcutsAreGlobal || globalKeys.has(key)) {\n return false;\n }\n if (isContentEditable) {\n // For events originating from an element in editing mode we only let\n // global key codes through.\n return true;\n }\n // Event target is one of (TEXTAREA, INPUT, BUTTON, SELECT).\n // Allow modifier shortcuts, unless we shouldn't.\n if (\n this.modifierShortcutsAreGlobal &&\n (event.altKey || event.ctrlKey || event.metaKey)\n ) {\n return true;\n }\n // Allow ENTER to be used as shortcut for text inputs.\n if (\n tagName === \"INPUT\" &&\n DEFAULT_TEXT_INPUTS.has((el).type)\n ) {\n return key !== \"enter\";\n }\n // Checkboxes, radiobuttons and buttons. Allow all but SPACE as shortcut.\n if (tagName === \"INPUT\" || tagName === \"BUTTON\") {\n // TODO(gboyer): If more flexibility is needed, create protected helper\n // methods for each case (e.g. button, input, etc).\n if (this.allowSpaceKeyOnButtons) {\n return false;\n }\n return key === \"space\";\n }\n // Don't allow any additional shortcut keys for textareas or selects.\n return true;\n }\n\n private handleKeyDown(event: KeyboardEvent) {\n const key = getEventKeyName(event);\n if (this.shouldIgnoreEvent(key, event)) {\n return;\n }\n dispatchEventWithModifiers(key, event, event, this.eventMap);\n }\n}\n\nexport function getEventKeyName(event: KeyboardEvent): string {\n return event.code.toLowerCase();\n}\n\nexport { EventActionMap, registerActionListener };\nexport type { EventActionMapInterface, ActionEvent };\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/checkbox_icon.css\";\n\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type { MakeIconOptions } from \"#src/widget/icon.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\n\nexport interface MakeCheckboxIconOptions\n extends Omit {\n enableTitle?: string;\n disableTitle?: string;\n backgroundScheme?: \"light\" | \"dark\";\n}\n\nexport class CheckboxIcon extends RefCounted {\n readonly element: HTMLElement;\n constructor(\n model: WatchableValueInterface,\n options: MakeCheckboxIconOptions,\n ) {\n super();\n this.element = makeIcon({\n ...options,\n onClick: () => {\n model.value = !model.value;\n },\n });\n this.element.classList.add(\"neuroglancer-checkbox-icon\");\n this.element.classList.add(\n options.backgroundScheme === \"dark\"\n ? \"dark-background\"\n : \"light-background\",\n );\n const updateView = () => {\n const value = model.value;\n this.element.dataset.checked = value ? \"true\" : \"false\";\n this.element.title =\n (value ? options.disableTitle : options.enableTitle) || \"\";\n };\n this.registerDisposer(model.changed.add(updateView));\n updateView();\n }\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport svg_copy from \"ikonate/icons/copy.svg?raw\";\nimport type { MakeIconOptions } from \"#src/widget/icon.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\n\nexport function makeCopyButton(options: MakeIconOptions = {}) {\n return makeIcon({ svg: svg_copy, ...options });\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { animationFrameDebounce } from \"#src/util/animation_frame_debounce.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { removeChildren } from \"#src/util/dom.js\";\nimport { WatchableVisibilityPriority } from \"#src/visibility_priority/frontend.js\";\n\nexport class DependentViewContext extends RefCounted {\n constructor(public redraw: () => void) {\n super();\n }\n}\n\nexport class DependentViewWidget extends RefCounted {\n element = document.createElement(\"div\");\n\n private generation = -1;\n private currentViewDisposer: RefCounted | undefined = undefined;\n private debouncedUpdateView = this.registerCancellable(\n animationFrameDebounce(() => this.updateView()),\n );\n private debouncedForceUpdateView = () => {\n this.generation = -1;\n this.debouncedUpdateView();\n };\n\n constructor(\n public model: WatchableValueInterface,\n public render: (\n value: T,\n parent: HTMLElement,\n context: DependentViewContext,\n ) => void,\n public visibility = new WatchableVisibilityPriority(\n WatchableVisibilityPriority.VISIBLE,\n ),\n ) {\n super();\n this.element.style.display = \"contents\";\n this.registerDisposer(model.changed.add(this.debouncedUpdateView));\n this.registerDisposer(\n visibility.changed.add(() => {\n if (this.visible) this.debouncedUpdateView();\n }),\n );\n this.updateView();\n }\n\n get visible() {\n return this.visibility.visible;\n }\n\n private updateView() {\n if (!this.visible) return;\n const { model } = this;\n const generation = model.changed.count;\n if (generation === this.generation) return;\n this.disposeCurrentView();\n const currentViewDisposer = (this.currentViewDisposer =\n new DependentViewContext(this.debouncedForceUpdateView));\n this.render(model.value, this.element, currentViewDisposer);\n this.generation = generation;\n }\n\n private disposeCurrentView() {\n const { currentViewDisposer } = this;\n if (currentViewDisposer !== undefined) {\n currentViewDisposer.dispose();\n }\n removeChildren(this.element);\n }\n\n disposed() {\n this.disposeCurrentView();\n super.disposed();\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type { TrackableEnum } from \"#src/util/trackable_enum.js\";\n\nexport class EnumSelectWidget extends RefCounted {\n element = document.createElement(\"select\");\n private valueIndexMap = new Map();\n constructor(public model: TrackableEnum) {\n super();\n const { element, valueIndexMap } = this;\n let index = 0;\n for (const key of Object.keys(model.enumType)) {\n if (Number.isNaN(Number(key))) {\n const option = document.createElement(\"option\");\n option.textContent = option.value = key.toLowerCase();\n element.appendChild(option);\n valueIndexMap.set(model.enumType[key], index);\n ++index;\n }\n }\n this.registerDisposer(model.changed.add(() => this.updateView()));\n this.registerEventListener(element, \"change\", () => this.updateModel());\n this.registerEventListener(element, \"wheel\", (event: WheelEvent) => {\n event.preventDefault();\n event.stopPropagation();\n this.adjustViaWheel(event);\n });\n this.updateView();\n }\n\n adjustViaWheel(event: WheelEvent) {\n const { element } = this;\n const { deltaY } = event;\n if (deltaY > 0) {\n element.selectedIndex =\n (element.options.length + element.selectedIndex - 1) %\n element.options.length;\n this.updateModel();\n } else if (deltaY < 0) {\n element.selectedIndex =\n (element.options.length + element.selectedIndex + 1) %\n element.options.length;\n this.updateModel();\n }\n }\n\n private updateView() {\n const { element } = this;\n element.selectedIndex = this.valueIndexMap.get(this.model.value)!;\n }\n\n private updateModel() {\n this.model.restoreState(this.element.value);\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { WatchableValue } from \"#src/trackable_value.js\";\nimport { TrackableValue } from \"#src/trackable_value.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { removeFromParent } from \"#src/util/dom.js\";\n\nexport class NumberInputWidget extends RefCounted {\n element = document.createElement(\"label\");\n inputElement = document.createElement(\"input\");\n validator: (x: number) => number;\n constructor(\n public model: WatchableValue,\n options: {\n validator?: (x: number) => number;\n label?: string;\n } = {},\n ) {\n super();\n let { validator, label } = options;\n const { element, inputElement } = this;\n if (validator === undefined) {\n if (model instanceof TrackableValue) {\n validator = model.validator;\n } else {\n validator = (x) => x;\n }\n }\n this.validator = validator;\n if (label !== undefined) {\n element.textContent = label;\n }\n element.appendChild(inputElement);\n element.className = \"neuroglancer-number-input\";\n inputElement.type = \"text\";\n this.registerDisposer(this.model.changed.add(() => this.updateView()));\n this.registerEventListener(inputElement, \"change\", () =>\n this.updateModel(),\n );\n this.updateView();\n }\n\n private updateView() {\n this.inputElement.value = \"\" + this.model.value;\n }\n\n updateModel() {\n let value = parseFloat(this.inputElement.value.trim());\n if (Number.isNaN(value)) {\n this.updateView();\n return;\n }\n try {\n value = this.validator(value);\n this.model.value = value;\n } catch {\n this.updateView();\n }\n }\n\n disposed() {\n removeFromParent(this.element);\n super.disposed();\n }\n}\n","/**\n * @license\n * Copyright 2017-2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/position_plot.css\";\n\nimport type {\n CoordinateSpace,\n DimensionId,\n} from \"#src/coordinate_transform.js\";\nimport {\n computeCombinedLowerUpperBound,\n getDisplayLowerUpperBounds,\n} from \"#src/coordinate_transform.js\";\nimport type { Position } from \"#src/navigation_state.js\";\nimport { WatchableValue } from \"#src/trackable_value.js\";\nimport { animationFrameDebounce } from \"#src/util/animation_frame_debounce.js\";\nimport { filterArrayInplace } from \"#src/util/array.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { startRelativeMouseDrag } from \"#src/util/mouse_drag.js\";\n\ninterface NormalizedDimensionBounds {\n lowerBound: number;\n upperBound: number;\n normalizedBounds: readonly { lower: number; upper: number }[];\n}\n\nfunction getCanvasYFromCoordinate(\n coordinate: number,\n lowerBound: number,\n upperBound: number,\n canvasHeight: number,\n) {\n return Math.floor(\n ((coordinate - lowerBound) * (canvasHeight - 1)) /\n (upperBound - lowerBound),\n );\n}\n\nfunction getNormalizedDimensionBounds(\n coordinateSpace: CoordinateSpace,\n dimensionIndex: number,\n height: number,\n): NormalizedDimensionBounds | undefined {\n const { boundingBoxes, bounds } = coordinateSpace;\n let [lowerBound, upperBound] = getDisplayLowerUpperBounds(\n bounds,\n dimensionIndex,\n );\n lowerBound = Math.floor(lowerBound);\n upperBound = Math.floor(upperBound - 1);\n if (!Number.isFinite(lowerBound) || !Number.isFinite(upperBound)) {\n return undefined;\n }\n const normalizedBounds: { lower: number; upper: number }[] = [];\n const normalize = (x: number) => {\n return getCanvasYFromCoordinate(x, lowerBound, upperBound, height);\n };\n const { rank } = coordinateSpace;\n for (const boundingBox of boundingBoxes) {\n const result = computeCombinedLowerUpperBound(\n boundingBox,\n dimensionIndex,\n rank,\n );\n if (result === undefined) continue;\n result.lower = Math.max(0, normalize(result.lower));\n result.upper = Math.min(height - 1, normalize(Math.ceil(result.upper - 1)));\n normalizedBounds.push(result);\n }\n normalizedBounds.sort((a, b) => {\n const lowerDiff = a.lower - b.lower;\n if (lowerDiff !== 0) return lowerDiff;\n return b.upper - b.upper;\n });\n filterArrayInplace(normalizedBounds, (x, i) => {\n if (i === 0) return true;\n const prev = normalizedBounds[i - 1];\n return prev.lower !== x.lower || prev.upper !== x.upper;\n });\n return { lowerBound, upperBound, normalizedBounds };\n}\n\nexport class PositionPlot extends RefCounted {\n element = document.createElement(\"div\");\n visible = true;\n dragging = new WatchableValue(false);\n\n tickWidth: number = this.orientation === \"column\" ? 10 : 5;\n barWidth: number = this.orientation === \"column\" ? 15 : 10;\n barRightMargin: number = this.orientation === \"column\" ? 10 : 2;\n canvasWidth: number;\n\n constructor(\n public position: Position,\n public dimensionId: DimensionId,\n public orientation: \"row\" | \"column\" = \"column\",\n ) {\n super();\n this.canvasWidth = this.tickWidth + this.barWidth + this.barRightMargin;\n const plotElement = this.element;\n plotElement.classList.add(\"neuroglancer-position-dimension-plot\");\n plotElement.dataset.orientation = orientation;\n const canvas = document.createElement(\"canvas\");\n const ctx = canvas.getContext(\"2d\")!;\n\n const lowerBoundElement = document.createElement(\"div\");\n const lowerBoundContainer = document.createElement(\"div\");\n lowerBoundContainer.appendChild(lowerBoundElement);\n const lowerBoundText = document.createTextNode(\"\");\n lowerBoundElement.appendChild(lowerBoundText);\n const upperBoundElement = document.createElement(\"div\");\n const hoverElement = document.createElement(\"div\");\n lowerBoundContainer.classList.add(\n \"neuroglancer-position-dimension-plot-lowerbound\",\n );\n upperBoundElement.classList.add(\n \"neuroglancer-position-dimension-plot-upperbound\",\n );\n hoverElement.classList.add(\n \"neuroglancer-position-dimension-plot-hoverposition\",\n );\n plotElement.appendChild(lowerBoundContainer);\n plotElement.appendChild(upperBoundElement);\n plotElement.appendChild(hoverElement);\n plotElement.appendChild(canvas);\n\n let prevLowerBound: number | undefined;\n let prevUpperBound: number | undefined;\n\n let hoverPosition: number | undefined = undefined;\n\n const updateView = () => {\n const coordinateSpace = this.position.coordinateSpace.value;\n const dimensionIndex = coordinateSpace.ids.indexOf(this.dimensionId);\n if (dimensionIndex === -1) return;\n\n let canvasHeight: number;\n if (orientation === \"column\") {\n canvasHeight = 100;\n canvas.width = this.canvasWidth;\n canvas.height = canvasHeight;\n upperBoundElement.style.marginTop = `${canvasHeight - 1}px`;\n } else {\n canvasHeight = canvas.clientWidth;\n canvas.width = canvasHeight;\n canvas.height = this.canvasWidth;\n }\n\n const normalizedDimensionBounds = getNormalizedDimensionBounds(\n coordinateSpace,\n dimensionIndex,\n canvasHeight,\n );\n if (\n normalizedDimensionBounds === undefined ||\n coordinateSpace.bounds.lowerBounds[dimensionIndex] + 1 ===\n coordinateSpace.bounds.upperBounds[dimensionIndex]\n ) {\n this.element.style.display = \"none\";\n this.visible = false;\n return;\n }\n this.visible = true;\n\n const { lowerBound, upperBound } = normalizedDimensionBounds;\n prevLowerBound = lowerBound;\n prevUpperBound = upperBound;\n lowerBoundText.textContent = lowerBound.toString();\n upperBoundElement.textContent = upperBound.toString();\n let canvasMargin: number;\n let lowerBoundWidth: number;\n let upperBoundWidth: number;\n if (orientation !== \"column\") {\n lowerBoundWidth = lowerBoundElement.clientWidth;\n upperBoundWidth = upperBoundElement.clientWidth;\n canvasMargin = Math.max(lowerBoundWidth, upperBoundWidth) / 2;\n canvas.style.marginLeft = `${canvasMargin}px`;\n canvas.style.marginRight = `${canvasMargin}px`;\n upperBoundElement.style.position = \"relative\";\n upperBoundElement.style.left = `${\n canvasHeight + canvasMargin - upperBoundWidth / 2\n }px`;\n lowerBoundElement.style.marginLeft = `${\n canvasMargin - lowerBoundWidth / 2\n }px`;\n }\n this.drawDimensionBounds(canvas, ctx, normalizedDimensionBounds);\n const curPosition = this.position.value[dimensionIndex];\n\n const drawPositionIndicator = (\n pos: number | undefined,\n fillStyle: string,\n ) => {\n if (\n pos !== undefined &&\n pos >= lowerBound &&\n Math.floor(pos) <= upperBound\n ) {\n ctx.fillStyle = fillStyle;\n const offset = getCanvasYFromCoordinate(\n pos,\n lowerBound,\n upperBound,\n canvasHeight,\n );\n if (orientation === \"column\") {\n ctx.fillRect(0, offset, this.canvasWidth, 1);\n } else {\n ctx.fillRect(offset, 0, 1, this.canvasWidth);\n }\n return offset;\n }\n return undefined;\n };\n const positionOffset = drawPositionIndicator(curPosition, \"#f66\");\n const isDragging = this.dragging.value;\n let hoverOffset = isDragging\n ? positionOffset\n : drawPositionIndicator(hoverPosition, \"#66f\");\n if (hoverOffset !== undefined) {\n hoverElement.textContent = (\n isDragging ? Math.floor(curPosition) : hoverPosition!\n ).toString();\n const lowerBoundOffset =\n orientation === \"column\"\n ? lowerBoundElement.clientHeight\n : lowerBoundElement.clientWidth;\n const upperBoundOffset =\n orientation === \"column\"\n ? upperBoundElement.clientHeight\n : upperBoundElement.clientWidth;\n let hoverWidth: number;\n let showLowerBound: boolean;\n let showUpperBound: boolean;\n if (orientation !== \"column\") {\n hoverWidth = hoverElement.clientWidth;\n hoverOffset += canvasMargin!;\n hoverOffset -= hoverWidth / 2;\n hoverOffset = Math.max(0, hoverOffset);\n const upperLimit =\n canvasHeight + canvasMargin! - upperBoundOffset / 2 - hoverWidth;\n showLowerBound = hoverOffset > canvasMargin! + lowerBoundOffset / 2;\n showUpperBound = hoverOffset < upperLimit;\n } else {\n showLowerBound = hoverOffset > lowerBoundOffset;\n showUpperBound = hoverOffset < canvasHeight - upperBoundOffset;\n }\n lowerBoundElement.style.visibility = showLowerBound ? \"\" : \"hidden\";\n upperBoundElement.style.visibility = showUpperBound ? \"\" : \"hidden\";\n hoverElement.style.display = \"\";\n hoverElement.style.visibility = \"visible\";\n if (orientation === \"column\") {\n hoverElement.style.marginTop = `${hoverOffset}px`;\n } else {\n hoverElement.style.marginLeft = `${hoverOffset}px`;\n }\n } else {\n lowerBoundElement.style.visibility = \"\";\n hoverElement.style.display = \"none\";\n upperBoundElement.style.visibility = \"\";\n }\n };\n const scheduleUpdateView = this.registerCancellable(\n animationFrameDebounce(updateView),\n );\n this.registerDisposer(this.position.changed.add(scheduleUpdateView));\n const getPositionFromMouseEvent = (\n event: MouseEvent,\n ): number | undefined => {\n if (prevLowerBound === undefined || prevUpperBound === undefined)\n return undefined;\n const canvasBounds = canvas.getBoundingClientRect();\n let relativeY: number;\n if (orientation === \"column\") {\n relativeY = (event.clientY - canvasBounds.top) / canvasBounds.height;\n } else {\n relativeY = (event.clientX - canvasBounds.left) / canvasBounds.width;\n }\n relativeY = Math.max(0, relativeY);\n relativeY = Math.min(1, relativeY);\n return (\n Math.round(relativeY * (prevUpperBound - prevLowerBound)) +\n prevLowerBound\n );\n };\n const setPositionFromMouse = (event: MouseEvent) => {\n const coordinateSpace = this.position.coordinateSpace.value;\n const dimensionIndex = coordinateSpace.ids.indexOf(this.dimensionId);\n if (dimensionIndex === -1) return;\n let x = getPositionFromMouseEvent(event);\n if (x === undefined) return;\n const { position } = this;\n const voxelCoordinates = position.value;\n if (\n !coordinateSpace.bounds.voxelCenterAtIntegerCoordinates[dimensionIndex]\n ) {\n x += 0.5;\n }\n voxelCoordinates[dimensionIndex] = x;\n position.value = voxelCoordinates;\n };\n\n canvas.addEventListener(\"pointermove\", (event: MouseEvent) => {\n const x = getPositionFromMouseEvent(event);\n hoverPosition = x;\n scheduleUpdateView();\n });\n canvas.addEventListener(\"pointerleave\", () => {\n hoverPosition = undefined;\n scheduleUpdateView();\n });\n\n canvas.addEventListener(\"pointerdown\", (event: MouseEvent) => {\n event.preventDefault();\n event.stopPropagation();\n if (event.ctrlKey || event.altKey || event.metaKey) {\n return;\n }\n startRelativeMouseDrag(\n event,\n (newEvent: MouseEvent) => {\n if (this.wasDisposed) return;\n hoverPosition = undefined;\n setPositionFromMouse(newEvent);\n scheduleUpdateView();\n this.dragging.value = true;\n },\n () => {\n this.dragging.value = false;\n scheduleUpdateView();\n },\n );\n setPositionFromMouse(event);\n });\n updateView();\n if (orientation === \"row\") {\n canvas.style.maxWidth = \"100%\";\n canvas.style.justifySelf = \"stretch\";\n const resizeObserver = new ResizeObserver(updateView);\n resizeObserver.observe(canvas);\n }\n }\n\n private drawDimensionBounds(\n canvas: HTMLCanvasElement,\n ctx: CanvasRenderingContext2D,\n bounds: NormalizedDimensionBounds,\n ) {\n const { orientation } = this;\n ctx.clearRect(0, 0, canvas.width, canvas.height);\n const { normalizedBounds } = bounds;\n const drawTick =\n orientation === \"column\"\n ? (x: number) => {\n ctx.fillRect(0, x, this.tickWidth, 1);\n }\n : (x: number) => {\n ctx.fillRect(x, 0, 1, this.tickWidth);\n };\n ctx.fillStyle = \"#fff\";\n for (const { lower, upper } of normalizedBounds) {\n drawTick(lower);\n drawTick(upper);\n }\n const length = normalizedBounds.length;\n ctx.fillStyle = \"#ccc\";\n for (let i = 0; i < length; ++i) {\n const { lower, upper } = normalizedBounds[i];\n const startX = Math.floor((i * this.barWidth) / length);\n const width = Math.max(1, this.barWidth / length);\n if (orientation === \"column\") {\n ctx.fillRect(startX + this.tickWidth, lower, width, upper + 1 - lower);\n } else {\n ctx.fillRect(lower, startX + this.tickWidth, upper + 1 - lower, width);\n }\n }\n }\n}\n","/**\n * @license\n * Copyright 2017-2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/position_widget.css\";\n\nimport svg_pause from \"ikonate/icons/pause.svg?raw\";\nimport svg_play from \"ikonate/icons/play.svg?raw\";\nimport svg_video from \"ikonate/icons/video.svg?raw\";\nimport type {\n CoordinateArray,\n CoordinateSpace,\n CoordinateSpaceCombiner,\n DimensionId,\n} from \"#src/coordinate_transform.js\";\nimport {\n clampAndRoundCoordinateToVoxelCenter,\n emptyInvalidCoordinateSpace,\n insertDimensionAt,\n makeCoordinateSpace,\n} from \"#src/coordinate_transform.js\";\nimport type { MouseSelectionState, UserLayer } from \"#src/layer/index.js\";\nimport type { LayerGroupViewer } from \"#src/layer_group_viewer.js\";\nimport type {\n CoordinateSpacePlaybackVelocity,\n Position,\n} from \"#src/navigation_state.js\";\nimport { VelocityBoundaryBehavior } from \"#src/navigation_state.js\";\nimport { StatusMessage } from \"#src/status.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport {\n makeCachedDerivedWatchableValue,\n WatchableValue,\n} from \"#src/trackable_value.js\";\nimport type { LocalToolBinder, ToolActivation } from \"#src/ui/tool.js\";\nimport {\n makeToolActivationStatusMessage,\n makeToolButton,\n registerTool,\n Tool,\n} from \"#src/ui/tool.js\";\nimport { animationFrameDebounce } from \"#src/util/animation_frame_debounce.js\";\nimport { arraysEqual, binarySearch } from \"#src/util/array.js\";\nimport { setClipboard } from \"#src/util/clipboard.js\";\nimport type { Borrowed } from \"#src/util/disposable.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport {\n removeFromParent,\n updateChildren,\n updateInputFieldWidth,\n} from \"#src/util/dom.js\";\nimport { vec3 } from \"#src/util/geom.js\";\nimport { verifyObjectProperty, verifyString } from \"#src/util/json.js\";\nimport type { ActionEvent } from \"#src/util/keyboard_bindings.js\";\nimport {\n KeyboardEventBinder,\n registerActionListener,\n} from \"#src/util/keyboard_bindings.js\";\nimport { EventActionMap, MouseEventBinder } from \"#src/util/mouse_bindings.js\";\nimport { formatScaleWithUnit, parseScale } from \"#src/util/si_units.js\";\nimport { TrackableEnum } from \"#src/util/trackable_enum.js\";\nimport { getWheelZoomAmount } from \"#src/util/wheel_zoom.js\";\nimport type { Viewer } from \"#src/viewer.js\";\nimport { CheckboxIcon } from \"#src/widget/checkbox_icon.js\";\nimport { makeCopyButton } from \"#src/widget/copy_button.js\";\nimport { DependentViewWidget } from \"#src/widget/dependent_view_widget.js\";\nimport { EnumSelectWidget } from \"#src/widget/enum_widget.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\nimport { NumberInputWidget } from \"#src/widget/number_input_widget.js\";\nimport { PositionPlot } from \"#src/widget/position_plot.js\";\n\nexport const positionDragType = \"neuroglancer-position\";\n\nconst inputEventMap = EventActionMap.fromObject({\n arrowup: { action: \"adjust-up\" },\n arrowdown: { action: \"adjust-down\" },\n arrowleft: { action: \"maybe-tab-backward\", preventDefault: false },\n arrowright: { action: \"maybe-tab-forward\", preventDefault: false },\n tab: { action: \"tab-forward\" },\n \"shift+tab\": { action: \"tab-backward\" },\n wheel: { action: \"adjust-via-wheel\" },\n \"alt+wheel\": { action: \"adjust-velocity-via-wheel\" },\n backspace: { action: \"delete-backward\", preventDefault: false },\n enter: { action: \"commit\" },\n escape: { action: \"cancel\" },\n});\n\nconst widgetFieldGetters: ((widget: DimensionWidget) => HTMLInputElement)[] = [\n (w) => w.nameElement,\n (w) => w.coordinate,\n (w) => w.scaleElement,\n];\n\n// Returns the coordinate array for the specified dimension, if valid.\n//\n// If no coordinate array is specified, returns `undefined`.\n//\n// If a coordinate array is specified but there is a unit or scale specified, returns `null`.\n//\n// Otherwise, returns the coordinate array.\nfunction getCoordinateArray(\n coordinateSpace: CoordinateSpace,\n dimensionIndex: number,\n): CoordinateArray | undefined | null {\n const coordinateArray = coordinateSpace.coordinateArrays[dimensionIndex];\n if (coordinateArray === undefined) return coordinateArray;\n if (\n coordinateSpace.units[dimensionIndex] !== \"\" ||\n coordinateSpace.scales[dimensionIndex] !== 1\n ) {\n return null;\n }\n return coordinateArray;\n}\n\nclass DimensionWidget {\n container = document.createElement(\"div\");\n nameContainer = document.createElement(\"span\");\n nameElement = document.createElement(\"input\");\n scaleContainer = document.createElement(\"span\");\n scaleElement = document.createElement(\"input\");\n coordinate = document.createElement(\"input\");\n coordinateLabel = document.createElement(\"span\");\n playButton = document.createElement(\"div\");\n pauseButton = document.createElement(\"div\");\n coordinateLabelWidth = 0;\n\n // Maximum possible position width given the current coordinate space.\n maxPositionWidth = 0;\n\n // Maximum position width seen so far.\n //\n // If the bounds are known when this DimensionWidget is first created, this is initialized to\n // `maxPositionWidth`. Otherwise it is initialized to `0`.\n maxPositionWidthSeen = 0;\n\n dropdownOwner: RefCounted | undefined = undefined;\n modified = false;\n draggingPosition = false;\n hasFocus = false;\n\n constructor(\n public coordinateSpace: CoordinateSpace,\n public id: DimensionId,\n initialDimensionIndex: number,\n options: { allowFocus: boolean; showPlayback: boolean },\n ) {\n const {\n container,\n scaleElement,\n scaleContainer,\n coordinate,\n nameElement,\n nameContainer,\n coordinateLabel,\n playButton,\n pauseButton,\n } = this;\n container.title = \"\";\n container.classList.add(\"neuroglancer-position-dimension\");\n const { allowFocus, showPlayback } = options;\n if (allowFocus) {\n container.draggable = true;\n container.tabIndex = -1;\n }\n container.appendChild(nameContainer);\n container.appendChild(scaleElement);\n nameContainer.appendChild(nameElement);\n nameContainer.title = `Drag to reorder, double click to rename. Names ending in ' or ^ indicate dimensions local to the layer; names ending in ^ indicate channel dimensions (image layers only).`;\n scaleContainer.appendChild(scaleElement);\n nameElement.classList.add(\"neuroglancer-position-dimension-name\");\n nameElement.disabled = true;\n nameElement.spellcheck = false;\n nameElement.autocomplete = \"off\";\n nameElement.required = true;\n nameElement.placeholder = \" \";\n scaleContainer.classList.add(\n \"neuroglancer-position-dimension-scale-container\",\n );\n scaleElement.classList.add(\"neuroglancer-position-dimension-scale\");\n scaleElement.disabled = true;\n scaleElement.spellcheck = false;\n scaleElement.autocomplete = \"off\";\n container.appendChild(scaleContainer);\n\n if (showPlayback) {\n playButton.classList.add(\"neuroglancer-icon\");\n pauseButton.classList.add(\"neuroglancer-icon\");\n playButton.innerHTML = svg_play;\n pauseButton.innerHTML = svg_pause;\n container.appendChild(playButton);\n container.appendChild(pauseButton);\n }\n\n container.appendChild(coordinate);\n coordinate.type = \"text\";\n coordinate.classList.add(\"neuroglancer-position-dimension-coordinate\");\n coordinate.spellcheck = false;\n coordinate.autocomplete = \"off\";\n coordinate.pattern = String.raw`(-?\\d+(?:\\.(?:\\d+)?)?)`;\n const coordinateArray = getCoordinateArray(\n coordinateSpace,\n initialDimensionIndex,\n );\n if (coordinateArray != null) {\n let maxLabelWidth = 0;\n for (const label of coordinateArray.labels) {\n maxLabelWidth = Math.max(maxLabelWidth, label.length);\n }\n this.coordinateLabelWidth = maxLabelWidth;\n coordinateLabel.style.width = `${maxLabelWidth + 2}ch`;\n container.appendChild(coordinateLabel);\n }\n coordinate.required = true;\n coordinate.placeholder = \" \";\n coordinateLabel.classList.add(\n \"neuroglancer-position-dimension-coordinate-label\",\n );\n\n if (allowFocus) {\n nameContainer.addEventListener(\"dblclick\", () => {\n nameElement.disabled = false;\n nameElement.focus();\n nameElement.select();\n });\n scaleContainer.addEventListener(\"dblclick\", () => {\n scaleElement.disabled = false;\n scaleElement.focus();\n scaleElement.select();\n });\n coordinate.addEventListener(\"focus\", () => {\n coordinate.select();\n });\n container.addEventListener(\"click\", (event: PointerEvent) => {\n if (\n !(event.target instanceof HTMLInputElement) ||\n event.target.disabled\n ) {\n coordinate.focus();\n }\n });\n }\n }\n}\n\n// Updates the width of the coordinate field to the max of:\n//\n// - The current size.\n//\n// - Maximum size seen so far, bounded by maximum width for the current lower/upper\n// bounds.\n//\n// The purpose of this is to avoid repeatedly changing the layout when using velocity, and also\n// changing the layout as Neuroglancer first loads and the bounds are not yet known.\nfunction updateCoordinateFieldWidth(widget: DimensionWidget, value: string) {\n const curLength = value.length;\n if (curLength > widget.maxPositionWidthSeen) {\n widget.maxPositionWidthSeen = curLength;\n }\n updateInputFieldWidth(\n widget.coordinate,\n Math.max(\n Math.min(widget.maxPositionWidth, widget.maxPositionWidthSeen),\n curLength,\n ),\n );\n}\n\nfunction updateScaleElementStyle(scaleElement: HTMLInputElement) {\n const { value } = scaleElement;\n updateInputFieldWidth(scaleElement);\n scaleElement.parentElement!.dataset.isEmpty = value === \"\" ? \"true\" : \"false\";\n}\n\nexport class PositionWidget extends RefCounted {\n element = document.createElement(\"div\");\n private dimensionContainer = document.createElement(\"div\");\n private coordinateSpace: CoordinateSpace | undefined = undefined;\n private velocity: CoordinateSpacePlaybackVelocity | undefined;\n private singleDimensionId: DimensionId | undefined;\n private getToolBinder: (() => LocalToolBinder | undefined) | undefined;\n private allowFocus: boolean;\n private showPlayback: boolean;\n\n private dimensionWidgets = new Map();\n private dimensionWidgetList: DimensionWidget[] = [];\n\n getDimensionIndex(id: DimensionId): number {\n const coordinateSpace = this.position.coordinateSpace.value;\n return coordinateSpace.ids.indexOf(id);\n }\n\n private openRegularDropdown(\n widget: DimensionWidget,\n dropdown: HTMLDivElement,\n ) {\n dropdown.classList.add(\"neuroglancer-position-dimension-dropdown\");\n\n const dropdownOwner = widget.dropdownOwner!;\n const toolBinder = this.getToolBinder?.();\n if (toolBinder !== undefined) {\n const dimensionIndex = this.getDimensionIndex(widget.id);\n const toolButton = makeToolButton(dropdownOwner, toolBinder, {\n toolJson: {\n type: DIMENSION_TOOL_ID,\n dimension: widget.coordinateSpace.names[dimensionIndex],\n },\n });\n dropdown.appendChild(toolButton);\n }\n\n const plot = dropdownOwner.registerDisposer(\n new PositionPlot(this.position, widget.id),\n );\n dropdown.appendChild(plot.element);\n\n const watchableVelocity = this.velocity?.dimensionVelocity(\n dropdownOwner,\n widget.id,\n );\n if (watchableVelocity !== undefined) {\n const playbackElement = document.createElement(\"div\");\n playbackElement.classList.add(\"neuroglancer-position-dimension-playback\");\n const header = document.createElement(\"div\");\n header.classList.add(\"neuroglancer-position-dimension-playback-header\");\n playbackElement.appendChild(header);\n header.appendChild(\n dropdownOwner.registerDisposer(\n new CheckboxIcon(this.velocity!.playbackEnabled(widget.id), {\n svg: svg_video,\n enableTitle: \"Enable playback/velocity\",\n disableTitle: \"Disable playback/velocity\",\n backgroundScheme: \"dark\",\n }),\n ).element,\n );\n header.appendChild(document.createTextNode(\"Playback\"));\n dropdown.appendChild(playbackElement);\n const enabled = dropdownOwner.registerDisposer(\n makeCachedDerivedWatchableValue(\n (value) => value !== undefined,\n [watchableVelocity],\n ),\n );\n playbackElement.appendChild(\n dropdownOwner.registerDisposer(\n new DependentViewWidget(enabled, (enabledValue, parent, context) => {\n if (!enabledValue) return;\n const velocityModel = new WatchableValue(0);\n velocityModel.changed.add(() => {\n const newValue = velocityModel.value;\n const velocity = watchableVelocity.value;\n if (velocity === undefined) return;\n if (velocity.velocity === newValue) return;\n watchableVelocity.value = { ...velocity, velocity: newValue };\n });\n const negateButton = makeIcon({\n text: \"±\",\n title: \"Negate velocity\",\n onClick: () => {\n velocityModel.value = -velocityModel.value;\n },\n });\n const velocityInputWidget = context.registerDisposer(\n new NumberInputWidget(velocityModel),\n );\n velocityInputWidget.element.insertBefore(\n negateButton,\n velocityInputWidget.element.firstChild,\n );\n velocityInputWidget.element.title =\n \"Velocity in coordinates per second\";\n const rateSpan = document.createElement(\"span\");\n rateSpan.textContent = \"/s\";\n velocityInputWidget.element.appendChild(rateSpan);\n parent.appendChild(velocityInputWidget.element);\n const trackableEnum = new TrackableEnum(\n VelocityBoundaryBehavior,\n VelocityBoundaryBehavior.STOP,\n );\n const watchableVelocityChanged = () => {\n trackableEnum.value =\n watchableVelocity.value?.atBoundary ??\n VelocityBoundaryBehavior.STOP;\n velocityModel.value = watchableVelocity.value?.velocity ?? 0;\n };\n watchableVelocityChanged();\n context.registerDisposer(\n watchableVelocity.changed.add(watchableVelocityChanged),\n );\n trackableEnum.changed.add(() => {\n const atBoundary = trackableEnum.value;\n const velocity = watchableVelocity.value;\n if (velocity === undefined) return;\n if (velocity.atBoundary === atBoundary) return;\n watchableVelocity.value = { ...velocity, atBoundary };\n });\n const selectWidget = new EnumSelectWidget(trackableEnum).element;\n parent.appendChild(selectWidget);\n selectWidget.title = \"Behavior when lower/upper bound is reached\";\n }),\n ).element,\n );\n }\n plot.dragging.changed.add(() => {\n const newValue = (widget.draggingPosition = plot.dragging.value);\n if (newValue === false) {\n this.updateDropdownVisibility(widget);\n }\n });\n }\n\n private openCoordinateArrayDropdown(\n widget: DimensionWidget,\n dropdown: HTMLDivElement,\n coordinateArray: CoordinateArray,\n ) {\n dropdown.classList.add(\n \"neuroglancer-position-dimension-coordinate-dropdown\",\n );\n const { coordinates, labels } = coordinateArray;\n const entries: {\n entryElement: HTMLDivElement;\n coordinateElement: HTMLDivElement;\n labelElement: HTMLDivElement;\n }[] = [];\n const length = coordinates.length;\n dropdown.style.setProperty(\n \"--neuroglancer-coordinate-label-width\",\n `${widget.coordinateLabelWidth}ch`,\n );\n for (let i = 0; i < length; ++i) {\n const entryElement = document.createElement(\"div\");\n entryElement.classList.add(\n \"neuroglancer-dimension-dropdown-coordinate-entry\",\n );\n const coordinateElement = document.createElement(\"div\");\n coordinateElement.classList.add(\n \"neuroglancer-dimension-dropdown-coordinate\",\n );\n const labelElement = document.createElement(\"div\");\n labelElement.classList.add(\n \"neuroglancer-dimension-dropdown-coordinate-label\",\n );\n labelElement.textContent = labels[i];\n coordinateElement.textContent = coordinates[i].toString();\n entryElement.appendChild(coordinateElement);\n entryElement.appendChild(labelElement);\n entryElement.addEventListener(\"click\", () => {\n const dimensionIndex = this.getDimensionIndex(widget.id);\n if (dimensionIndex === -1) return;\n const { position } = this;\n const voxelCoordinates = position.value;\n voxelCoordinates[dimensionIndex] = coordinates[i] + 0.5;\n widget.modified = false;\n position.value = voxelCoordinates;\n });\n dropdown.appendChild(entryElement);\n entries.push({ entryElement, coordinateElement, labelElement });\n }\n // const dropdownOwner = widget.dropdownOwner!;\n }\n\n private openDropdown(widget: DimensionWidget) {\n if (widget.dropdownOwner !== undefined) return;\n const dimensionIndex = this.getDimensionIndex(widget.id);\n if (dimensionIndex === -1) return;\n this.closeDropdown();\n const dropdownOwner = (widget.dropdownOwner = new RefCounted());\n const dropdown = document.createElement(\"div\");\n dropdown.draggable = true;\n dropdown.addEventListener(\"dragstart\", (event) => {\n event.stopPropagation();\n event.preventDefault();\n });\n dropdown.addEventListener(\"pointerenter\", () => {\n widget.hasFocus = true;\n });\n dropdown.tabIndex = -1;\n widget.container.appendChild(dropdown);\n\n const coordinateArray = getCoordinateArray(\n widget.coordinateSpace,\n dimensionIndex,\n );\n if (coordinateArray == null) {\n this.openRegularDropdown(widget, dropdown);\n } else {\n this.openCoordinateArrayDropdown(widget, dropdown, coordinateArray);\n }\n\n this.widgetWithOpenDropdown = widget;\n\n dropdownOwner.registerDisposer(() => {\n removeFromParent(dropdown);\n widget.dropdownOwner = undefined;\n widget.container.dataset.dropdownVisible = undefined;\n this.widgetWithOpenDropdown = undefined;\n });\n\n dropdownOwner.registerEventListener(\n document,\n \"pointerdown\",\n (event: MouseEvent) => {\n const { target } = event;\n if (target instanceof Node && widget.container.contains(target)) {\n return;\n }\n this.closeDropdown(widget);\n },\n { capture: true },\n );\n }\n\n private widgetWithOpenDropdown: DimensionWidget | undefined;\n\n private closeDropdown(widget = this.widgetWithOpenDropdown) {\n if (widget === undefined) return;\n const { dropdownOwner } = widget;\n if (dropdownOwner === undefined) return;\n dropdownOwner.dispose();\n }\n\n private pasteString(widget: DimensionWidget, s: string) {\n while (true) {\n widget.coordinate.focus();\n const m = s.match(\n /^\\s*(-?\\d+(?:\\.(?:\\d+)?)?)((?:\\s+(?![\\s,]))|(?:\\s*,\\s*))?/,\n );\n if (m === null) break;\n if (m[1] !== undefined) {\n document.execCommand(\"insertText\", undefined, m[1]);\n }\n if (m[2] !== undefined) {\n const { dimensionWidgetList } = this;\n const dimensionIndex = dimensionWidgetList.indexOf(widget);\n if (\n dimensionIndex === -1 ||\n dimensionIndex + 1 === dimensionWidgetList.length\n ) {\n break;\n }\n const remaining = s.substring(m[0].length);\n const nextWidget = dimensionWidgetList[dimensionIndex + 1];\n widget = nextWidget;\n s = remaining;\n continue;\n }\n break;\n }\n }\n\n private dragSource: DimensionWidget | undefined = undefined;\n\n private reorderDimensionTo(targetIndex: number, sourceIndex: number) {\n if (targetIndex === sourceIndex) return;\n const { coordinateSpace } = this.position;\n coordinateSpace.value = insertDimensionAt(\n coordinateSpace.value,\n targetIndex,\n sourceIndex,\n );\n }\n\n private updateDropdownVisibility(widget: DimensionWidget) {\n if (widget.hasFocus || widget.draggingPosition) {\n this.openDropdown(widget);\n } else {\n this.closeDropdown(widget);\n }\n }\n\n private newDimension(\n coordinateSpace: CoordinateSpace,\n id: DimensionId,\n initialDimensionIndex: number,\n ) {\n const widget = new DimensionWidget(\n coordinateSpace,\n id,\n initialDimensionIndex,\n { allowFocus: this.allowFocus, showPlayback: this.showPlayback },\n );\n if (this.singleDimensionId === undefined) {\n widget.container.addEventListener(\"dragstart\", (event: DragEvent) => {\n this.dragSource = widget;\n event.stopPropagation();\n event.dataTransfer!.setData(\"neuroglancer-dimension\", \"\");\n });\n widget.container.addEventListener(\"dragenter\", (event: DragEvent) => {\n const { dragSource } = this;\n if (dragSource === undefined || dragSource === widget) return;\n const { dimensionWidgetList } = this;\n const sourceIndex = dimensionWidgetList.indexOf(dragSource);\n const targetIndex = dimensionWidgetList.indexOf(widget);\n if (sourceIndex === -1 || targetIndex === -1) return;\n event.preventDefault();\n this.reorderDimensionTo(targetIndex, sourceIndex);\n });\n widget.container.addEventListener(\"dragend\", (event: DragEvent) => {\n event;\n if (this.dragSource === widget) {\n this.dragSource = undefined;\n }\n });\n }\n if (this.allowFocus) {\n widget.container.addEventListener(\"focusin\", () => {\n widget.hasFocus = true;\n this.updateDropdownVisibility(widget);\n });\n widget.container.addEventListener(\"focusout\", (event: FocusEvent) => {\n const { relatedTarget } = event;\n if (\n relatedTarget instanceof Node &&\n widget.container.contains(relatedTarget)\n ) {\n return;\n }\n widget.hasFocus = false;\n this.updateDropdownVisibility(widget);\n });\n widget.coordinate.addEventListener(\"paste\", (event: ClipboardEvent) => {\n const input = widget.coordinate;\n const value = input.value;\n const { clipboardData } = event;\n if (clipboardData === null) return;\n let text = clipboardData.getData(\"text\");\n let { selectionEnd, selectionStart } = input;\n if (selectionStart !== 0 || selectionEnd !== value.length) {\n if (selectionStart == null) selectionStart = 0;\n if (selectionEnd == null) selectionEnd = 0;\n const invalidMatch = text.match(/[^\\-0-9.]/);\n if (invalidMatch !== null) {\n text = text.substring(0, invalidMatch.index);\n }\n if (text.length > 0) {\n document.execCommand(\"insertText\", undefined, text);\n }\n } else {\n this.pasteString(widget, text);\n }\n event.preventDefault();\n event.stopPropagation();\n });\n widget.coordinate.addEventListener(\"input\", () => {\n widget.modified = true;\n const input = widget.coordinate;\n const value = input.value;\n let { selectionDirection, selectionEnd, selectionStart } = input;\n if (selectionStart === null) selectionStart = 0;\n if (selectionEnd === null) selectionEnd = selectionStart;\n let newValue = \"\";\n const invalidPattern = /[^\\-0-9.]/g;\n newValue += value\n .substring(0, selectionStart)\n .replace(invalidPattern, \"\");\n const newSelectionStart = newValue.length;\n newValue += value\n .substring(selectionStart, selectionEnd)\n .replace(invalidPattern, \"\");\n const newSelectionEnd = newValue.length;\n newValue += value.substring(selectionEnd).replace(invalidPattern, \"\");\n input.value = newValue;\n input.selectionStart = newSelectionStart;\n input.selectionEnd = newSelectionEnd;\n input.selectionDirection = selectionDirection;\n updateCoordinateFieldWidth(widget, newValue);\n if (\n selectionEnd === selectionStart &&\n selectionEnd === value.length &&\n value.match(/^(-?\\d+(?:\\.(?:\\d+)?)?)((?:\\s+(?![\\s,]))|(?:\\s*,\\s*))$/)\n ) {\n this.selectAdjacentCoordinate(widget, 1);\n }\n });\n\n widget.nameElement.addEventListener(\"input\", () => {\n const { nameElement } = widget;\n updateInputFieldWidth(nameElement);\n this.updateNameValidity();\n });\n\n widget.scaleElement.addEventListener(\"input\", () => {\n const { scaleElement } = widget;\n updateScaleElementStyle(scaleElement);\n this.updateScaleValidity(widget);\n });\n\n widget.coordinate.addEventListener(\"blur\", (event) => {\n const { relatedTarget } = event;\n if (\n this.dimensionWidgetList.some(\n (widget) => widget.coordinate === relatedTarget,\n )\n ) {\n return;\n }\n if (widget.modified) {\n this.updatePosition();\n }\n });\n\n widget.nameElement.addEventListener(\"blur\", (event) => {\n widget.nameElement.disabled = true;\n const { relatedTarget } = event;\n if (\n this.dimensionWidgetList.some(\n (widget) => widget.nameElement === relatedTarget,\n )\n ) {\n return;\n }\n if (!this.updateNames()) {\n this.forceUpdateDimensions();\n }\n });\n\n widget.scaleElement.addEventListener(\"blur\", (event) => {\n widget.scaleElement.disabled = true;\n const { relatedTarget } = event;\n if (\n this.dimensionWidgetList.some(\n (widget) => widget.scaleElement === relatedTarget,\n )\n ) {\n return;\n }\n if (!this.updateScales()) {\n this.forceUpdateDimensions();\n }\n });\n } else {\n widget.coordinate.disabled = true;\n }\n\n registerActionListener(\n widget.container,\n \"adjust-via-wheel\",\n (actionEvent) => {\n const event = actionEvent.detail;\n const { deltaY } = event;\n if (deltaY === 0) {\n return;\n }\n this.adjustDimensionPosition(widget.id, Math.sign(deltaY));\n },\n );\n\n registerActionListener(\n widget.container,\n \"adjust-velocity-via-wheel\",\n (actionEvent) => {\n const event = actionEvent.detail;\n this.adjustDimensionVelocity(widget, getWheelZoomAmount(event));\n },\n );\n\n registerActionListener(widget.container, \"adjust-up\", () => {\n this.adjustDimensionPosition(widget.id, -1);\n });\n registerActionListener(widget.container, \"adjust-down\", () => {\n this.adjustDimensionPosition(widget.id, 1);\n });\n\n for (const getter of widgetFieldGetters) {\n const e = getter(widget);\n registerActionListener(e, \"maybe-tab-forward\", (event) => {\n this.handleLeftRightMovement(event, widget, 1, getter);\n });\n registerActionListener(e, \"maybe-tab-backward\", (event) => {\n this.handleLeftRightMovement(event, widget, -1, getter);\n });\n registerActionListener(e, \"tab-forward\", () => {\n this.selectAdjacentField(widget, 1, getter);\n });\n registerActionListener(e, \"tab-backward\", () => {\n this.selectAdjacentField(widget, -1, getter);\n });\n }\n\n registerActionListener(widget.coordinate, \"commit\", () => {\n this.updatePosition();\n });\n\n registerActionListener(widget.nameElement, \"commit\", () => {\n this.updateNames();\n });\n\n registerActionListener(widget.scaleElement, \"commit\", () => {\n this.updateScales();\n });\n\n registerActionListener(widget.coordinate, \"delete-backward\", (event) => {\n event.stopPropagation();\n const { coordinate } = widget;\n if (\n coordinate.selectionStart === coordinate.selectionEnd &&\n coordinate.selectionStart === 0\n ) {\n event.preventDefault();\n this.selectAdjacentCoordinate(widget, -1);\n }\n });\n\n if (this.showPlayback) {\n const setPaused = (paused: boolean) => {\n this.velocity?.togglePlayback(widget.id, paused);\n };\n widget.playButton.addEventListener(\"click\", () => setPaused(false));\n widget.pauseButton.addEventListener(\"click\", () => setPaused(true));\n }\n\n return widget;\n }\n\n private forceUpdateDimensions() {\n let {\n position: {\n coordinateSpace: { value: coordinateSpace },\n },\n } = this;\n if (!coordinateSpace.valid) {\n coordinateSpace = emptyInvalidCoordinateSpace;\n }\n this.coordinateSpace = coordinateSpace;\n const { dimensionWidgets, dimensionWidgetList } = this;\n dimensionWidgetList.length = 0;\n const {\n names,\n ids,\n scales,\n units,\n bounds: { lowerBounds, upperBounds },\n } = coordinateSpace;\n const getDimensionWidget = (id: DimensionId, i: number) => {\n // Calculate max position width.\n const lower = lowerBounds[i];\n const upper = upperBounds[i];\n const maxPositionWidth = Math.max(\n Number.isFinite(lower) ? Math.floor(lower).toString().length : 0,\n Number.isFinite(upper) ? Math.ceil(upper).toString().length : 0,\n );\n let widget = dimensionWidgets.get(id);\n if (widget === undefined) {\n widget = this.newDimension(coordinateSpace, id, i);\n dimensionWidgets.set(id, widget);\n widget.maxPositionWidthSeen = maxPositionWidth;\n } else {\n widget.coordinateSpace = coordinateSpace;\n }\n widget.maxPositionWidth = maxPositionWidth;\n const name = names[i];\n widget.nameElement.value = name;\n widget.nameElement.dataset.isValid = undefined;\n updateInputFieldWidth(widget.nameElement);\n const coordinateArray = getCoordinateArray(coordinateSpace, i);\n if (coordinateArray === undefined) {\n widget.container.dataset.coordinateArray = \"none\";\n } else if (coordinateArray === null) {\n widget.container.dataset.coordinateArray = \"invalid\";\n } else {\n widget.container.dataset.coordinateArray = \"valid\";\n }\n widget.scaleContainer.title =\n \"Drag to reorder, double click to change scale\";\n if (coordinateArray === null) {\n widget.scaleContainer.title +=\n \". Coordinate array disabled. To use the coordinate array, remove the unit/scale.\";\n }\n const { scale, prefix, unit } = formatScaleWithUnit(scales[i], units[i]);\n const scaleString = `${scale}${prefix}${unit}`;\n widget.scaleElement.value = scaleString;\n widget.scaleElement.dataset.isValid = undefined;\n updateScaleElementStyle(widget.scaleElement);\n dimensionWidgetList.push(widget);\n return widget.container;\n };\n const { singleDimensionId } = this;\n if (singleDimensionId !== undefined) {\n const dimensionIndex = this.getDimensionIndex(singleDimensionId);\n if (dimensionIndex === -1) {\n updateChildren(this.dimensionContainer, []);\n } else {\n updateChildren(this.dimensionContainer, [\n getDimensionWidget(singleDimensionId, dimensionIndex),\n ]);\n }\n } else {\n updateChildren(this.dimensionContainer, ids.map(getDimensionWidget));\n }\n for (const [id, widget] of dimensionWidgets) {\n if (widget.coordinateSpace !== coordinateSpace) {\n this.closeDropdown(widget);\n dimensionWidgets.delete(id);\n }\n }\n }\n\n private updateDimensions() {\n const {\n position: {\n coordinateSpace: { value: coordinateSpace },\n },\n } = this;\n if (coordinateSpace === this.coordinateSpace) return;\n this.forceUpdateDimensions();\n }\n\n private selectAdjacentField(\n widget: DimensionWidget,\n dir: number,\n fieldGetter: (widget: DimensionWidget) => HTMLInputElement,\n ) {\n const { dimensionWidgetList } = this;\n let axisIndex = dimensionWidgetList.indexOf(widget);\n if (axisIndex === -1) return;\n while (true) {\n axisIndex += dir;\n if (axisIndex < 0 || axisIndex >= dimensionWidgetList.length) {\n return false;\n }\n const newWidget = dimensionWidgetList[axisIndex];\n const field = fieldGetter(newWidget);\n if (field.style.display === \"none\") continue;\n field.disabled = false;\n field.focus();\n field.selectionStart = 0;\n field.selectionEnd = field.value.length;\n field.selectionDirection = dir === 1 ? \"forward\" : \"backward\";\n return true;\n }\n }\n\n private selectAdjacentCoordinate(widget: DimensionWidget, dir: number) {\n return this.selectAdjacentField(widget, dir, (w) => w.coordinate);\n }\n\n private handleLeftRightMovement(\n event: ActionEvent,\n widget: DimensionWidget,\n dir: number,\n getter: (widget: DimensionWidget) => HTMLInputElement,\n ) {\n event.stopPropagation();\n const element = getter(widget);\n if (\n element.selectionStart !== element.selectionEnd ||\n element.selectionStart !== (dir === 1 ? element.value.length : 0)\n ) {\n return;\n }\n if (this.selectAdjacentField(widget, dir, getter)) {\n event.preventDefault();\n }\n }\n\n private updateNameValidity() {\n const { dimensionWidgetList } = this;\n const names = dimensionWidgetList.map((w) => w.nameElement.value);\n const rank = names.length;\n const isValid = this.combiner.getRenameValidity(names);\n for (let i = 0; i < rank; ++i) {\n dimensionWidgetList[i].nameElement.dataset.isValid =\n isValid[i] === false ? \"false\" : \"true\";\n }\n }\n\n private updateScaleValidity(widget: DimensionWidget) {\n const isValid = parseScale(widget.scaleElement.value) !== undefined;\n widget.scaleElement.dataset.isValid = isValid.toString();\n }\n\n constructor(\n public position: Borrowed,\n public combiner: CoordinateSpaceCombiner,\n {\n copyButton = true,\n velocity = undefined,\n singleDimensionId = undefined,\n getToolBinder = undefined,\n allowFocus = true,\n showPlayback = true,\n }: {\n copyButton?: boolean;\n velocity?: CoordinateSpacePlaybackVelocity;\n singleDimensionId?: DimensionId;\n getToolBinder?: (() => LocalToolBinder | undefined) | undefined;\n allowFocus?: boolean;\n showPlayback?: boolean;\n } = {},\n ) {\n super();\n const { element, dimensionContainer } = this;\n this.velocity = velocity;\n this.singleDimensionId = singleDimensionId;\n this.getToolBinder = getToolBinder;\n this.allowFocus = allowFocus;\n this.showPlayback = showPlayback;\n this.registerDisposer(\n position.coordinateSpace.changed.add(\n this.registerCancellable(\n animationFrameDebounce(() => this.updateDimensions()),\n ),\n ),\n );\n element.className = \"neuroglancer-position-widget\";\n dimensionContainer.style.display = \"contents\";\n element.appendChild(dimensionContainer);\n if (copyButton) {\n const copyButton = makeCopyButton({\n title: \"Copy position to clipboard\",\n onClick: () => {\n const result = setClipboard(this.getPositionText());\n StatusMessage.showTemporaryMessage(\n result\n ? \"Position copied to clipboard\"\n : \"Failed to copy position to clipboard\",\n );\n },\n });\n copyButton.addEventListener(\"dragstart\", (event) => {\n event.dataTransfer!.setData(\n positionDragType,\n JSON.stringify({\n position: position.toJSON(),\n dimensions: position.coordinateSpace.value.names,\n }),\n );\n event.dataTransfer!.setData(\"text\", this.getPositionText());\n event.stopPropagation();\n });\n copyButton.draggable = true;\n element.appendChild(copyButton);\n }\n\n const debouncedUpdateView = this.registerCancellable(\n animationFrameDebounce(() => this.updateView()),\n );\n this.registerDisposer(position.changed.add(debouncedUpdateView));\n if (velocity !== undefined) {\n this.registerDisposer(velocity.changed.add(debouncedUpdateView));\n }\n\n const shouldIgnoreEvent = (event: Event) => {\n const target = event.target;\n if (\n target instanceof Element &&\n target.matches(\".neuroglancer-position-dimension-playback *\")\n ) {\n return true;\n }\n return false;\n };\n if (allowFocus) {\n const keyboardHandler = this.registerDisposer(\n new KeyboardEventBinder(element, inputEventMap),\n );\n keyboardHandler.allShortcutsAreGlobal = true;\n keyboardHandler.shouldIgnore = shouldIgnoreEvent;\n }\n const mouseHandler = this.registerDisposer(\n new MouseEventBinder(element, inputEventMap),\n );\n mouseHandler.shouldIgnore = shouldIgnoreEvent;\n this.registerDisposer(\n registerActionListener(element, \"cancel\", (event) => {\n this.coordinateSpace = undefined;\n this.updateView();\n this.closeDropdown();\n const { target } = event;\n if (target instanceof HTMLElement) {\n target.blur();\n }\n }),\n );\n this.updateView();\n }\n\n adjustDimensionPosition(id: DimensionId, adjustment: number) {\n const axisIndex = this.getDimensionIndex(id);\n if (axisIndex === -1) return;\n this.updatePosition();\n const { position } = this;\n if (!position.valid) {\n return;\n }\n const coordinateSpace = position.coordinateSpace.value;\n const { bounds } = coordinateSpace;\n const voxelCoordinates = Float32Array.from(position.value);\n voxelCoordinates[axisIndex] = clampAndRoundCoordinateToVoxelCenter(\n bounds,\n axisIndex,\n voxelCoordinates[axisIndex] + adjustment,\n );\n this.position.value = voxelCoordinates;\n this.updateView();\n }\n\n adjustDimensionVelocity(widget: DimensionWidget, factor: number) {\n const { velocity } = this;\n if (velocity === undefined) return;\n velocity.multiplyVelocity(widget.id, factor);\n }\n\n private updatePosition() {\n if (!this.allowFocus) return;\n const { dimensionWidgetList } = this;\n const { position } = this;\n const { value: voxelCoordinates } = position;\n const coordinateSpace = position.coordinateSpace.value;\n if (voxelCoordinates === undefined) return;\n const rank = dimensionWidgetList.length;\n let modified = false;\n for (let i = 0; i < rank; ++i) {\n const widget = dimensionWidgetList[i];\n if (!widget.modified) continue;\n widget.modified = false;\n modified = true;\n const valueString = widget.coordinate.value;\n let value = Number(valueString);\n if (!Number.isFinite(value)) continue;\n // If `valueString` contains a decimal point, don't adjust to voxel center.\n if (\n Number.isInteger(value) &&\n !valueString.includes(\".\") &&\n coordinateSpace !== undefined &&\n !coordinateSpace.bounds.voxelCenterAtIntegerCoordinates[i]\n ) {\n value += 0.5;\n }\n voxelCoordinates[i] = value;\n }\n if (modified) {\n position.value = voxelCoordinates;\n }\n }\n\n private updateNames() {\n if (!this.allowFocus) return;\n const { dimensionWidgetList } = this;\n const {\n position: { coordinateSpace },\n } = this;\n const existing = coordinateSpace.value;\n const names = dimensionWidgetList.map((x) => x.nameElement.value);\n if (this.combiner.getRenameValidity(names).includes(false)) return false;\n const existingNames = existing.names;\n if (arraysEqual(existingNames, names)) return false;\n const timestamps = existing.timestamps.map((t, i) =>\n existingNames[i] === names[i] ? t : Date.now(),\n );\n const newSpace = { ...existing, names, timestamps };\n coordinateSpace.value = newSpace;\n return true;\n }\n\n private updateScales() {\n if (!this.allowFocus) return;\n const { dimensionWidgetList } = this;\n const {\n position: { coordinateSpace },\n } = this;\n const existing = coordinateSpace.value;\n const scalesAndUnits = dimensionWidgetList.map((x) =>\n parseScale(x.scaleElement.value),\n );\n if (scalesAndUnits.includes(undefined)) {\n return false;\n }\n const newScales = Float64Array.from(scalesAndUnits, (x) => x!.scale);\n const newUnits = Array.from(scalesAndUnits, (x) => x!.unit);\n const { scales, units } = existing;\n if (arraysEqual(scales, newScales) && arraysEqual(units, newUnits))\n return false;\n const timestamps = existing.timestamps.map((t, i) =>\n newScales[i] === scales[i] && newUnits[i] === units[i] ? t : Date.now(),\n );\n const newSpace = makeCoordinateSpace({\n valid: existing.valid,\n rank: existing.rank,\n scales: newScales,\n units: newUnits,\n timestamps,\n ids: existing.ids,\n names: existing.names,\n boundingBoxes: existing.boundingBoxes,\n coordinateArrays: existing.coordinateArrays,\n });\n coordinateSpace.value = newSpace;\n return true;\n }\n\n private getPositionText() {\n const { position } = this;\n if (position.valid) {\n return position.value.map((x) => Math.floor(x)).join(\", \");\n }\n return \"\";\n }\n\n private updateView() {\n this.updateDimensions();\n const {\n position: { value: voxelCoordinates },\n dimensionWidgetList,\n } = this;\n const rank = dimensionWidgetList.length;\n if (voxelCoordinates === undefined) {\n return;\n }\n const coordinateSpace = this.coordinateSpace!;\n const { velocity } = this;\n for (let i = 0; i < rank; ++i) {\n const widget = dimensionWidgetList[i];\n const inputElement = widget.coordinate;\n const newCoord = Math.floor(voxelCoordinates[i]);\n const newValue = newCoord.toString();\n updateCoordinateFieldWidth(widget, newValue);\n inputElement.value = newValue;\n const coordinateArray = getCoordinateArray(coordinateSpace, i);\n let label = \"\";\n if (coordinateArray != null) {\n const { coordinates } = coordinateArray;\n const index = binarySearch(coordinates, newCoord, (a, b) => a - b);\n if (index !== coordinates.length) {\n label = coordinateArray.labels[index];\n }\n }\n const labelElement = widget.coordinateLabel;\n labelElement.textContent = label;\n if (this.showPlayback) {\n const velocityInfo = velocity?.value?.[i];\n if (velocityInfo !== undefined) {\n const paused = velocityInfo.paused;\n widget.playButton.style.display = paused ? \"\" : \"none\";\n widget.pauseButton.style.display = !paused ? \"\" : \"none\";\n } else {\n widget.playButton.style.display = \"none\";\n widget.pauseButton.style.display = \"none\";\n }\n }\n }\n }\n\n disposed() {\n this.closeDropdown();\n removeFromParent(this.element);\n super.disposed();\n }\n}\n\nexport class MousePositionWidget extends RefCounted {\n tempPosition = vec3.create();\n constructor(\n public element: HTMLElement,\n public mouseState: MouseSelectionState,\n public coordinateSpace: WatchableValueInterface<\n CoordinateSpace | undefined\n >,\n ) {\n super();\n element.className = \"neuroglancer-mouse-position-widget\";\n const updateViewFunction = this.registerCancellable(\n animationFrameDebounce(() => this.updateView()),\n );\n this.registerDisposer(mouseState.changed.add(updateViewFunction));\n this.registerDisposer(coordinateSpace.changed.add(updateViewFunction));\n }\n updateView() {\n let text = \"\";\n const {\n mouseState,\n coordinateSpace: { value: coordinateSpace },\n } = this;\n if (mouseState.active && coordinateSpace !== undefined) {\n const p = mouseState.position;\n const { rank, names } = coordinateSpace;\n for (let i = 0; i < rank; ++i) {\n if (i !== 0) text += \" \";\n text += `${names[i]} ${Math.floor(p[i])}`;\n }\n }\n this.element.textContent = text;\n }\n disposed() {\n removeFromParent(this.element);\n super.disposed();\n }\n}\n\nconst DIMENSION_TOOL_ID = \"dimension\";\n\ninterface SupportsDimensionTool {\n position: Position;\n velocity: CoordinateSpacePlaybackVelocity;\n coordinateSpaceCombiner: CoordinateSpaceCombiner;\n toolBinder: LocalToolBinder;\n}\n\nconst TOOL_INPUT_EVENT_MAP = EventActionMap.fromObject({\n \"at:shift?+wheel\": { action: \"adjust-position-via-wheel\" },\n \"at:shift?+alt+wheel\": { action: \"adjust-velocity-via-wheel\" },\n \"shift?+alt?+space\": { action: \"toggle-playback\" },\n \"at:shift?+alt?+mousedown0\": { action: \"toggle-playback\" },\n});\n\nclass DimensionTool extends Tool {\n get position() {\n return this.viewer.position;\n }\n get velocity() {\n return this.viewer.velocity;\n }\n get coordinateSpace() {\n return this.viewer.coordinateSpaceCombiner.combined;\n }\n\n activate(activation: ToolActivation) {\n const { viewer } = this;\n const { content } = makeToolActivationStatusMessage(activation);\n content.classList.add(\"neuroglancer-position-tool\");\n activation.bindInputEventMap(TOOL_INPUT_EVENT_MAP);\n const positionWidget = new PositionWidget(\n viewer.position,\n viewer.coordinateSpaceCombiner,\n {\n velocity: viewer.velocity,\n singleDimensionId: this.dimensionId,\n copyButton: false,\n allowFocus: false,\n showPlayback: false,\n },\n );\n positionWidget.element.style.userSelect = \"none\";\n content.appendChild(activation.registerDisposer(positionWidget).element);\n const plot = activation.registerDisposer(\n new PositionPlot(viewer.position, this.dimensionId, \"row\"),\n );\n plot.element.style.flex = \"1\";\n content.appendChild(plot.element);\n activation.bindAction(\n \"adjust-position-via-wheel\",\n (actionEvent) => {\n actionEvent.stopPropagation();\n const event = actionEvent.detail;\n const { deltaY } = event;\n if (deltaY === 0) {\n return;\n }\n positionWidget.adjustDimensionPosition(\n this.dimensionId,\n Math.sign(deltaY),\n );\n },\n );\n\n const watchableVelocity = this.velocity.dimensionVelocity(\n activation,\n this.dimensionId,\n );\n const enabled = activation.registerDisposer(\n makeCachedDerivedWatchableValue(\n (value) => value !== undefined,\n [watchableVelocity],\n ),\n );\n content.appendChild(\n activation.registerDisposer(\n new DependentViewWidget(enabled, (enabledValue, parent, context) => {\n if (!enabledValue) return;\n parent.classList.add(\"neuroglancer-position-dimension-playback\");\n const playButton = document.createElement(\"div\");\n const pauseButton = document.createElement(\"div\");\n playButton.classList.add(\"neuroglancer-icon\");\n pauseButton.classList.add(\"neuroglancer-icon\");\n playButton.innerHTML = svg_play;\n pauseButton.innerHTML = svg_pause;\n parent.appendChild(playButton);\n parent.appendChild(pauseButton);\n const togglePlayback = () =>\n viewer.velocity.togglePlayback(this.dimensionId);\n playButton.addEventListener(\"click\", togglePlayback);\n pauseButton.addEventListener(\"click\", togglePlayback);\n const updatePlayPause = () => {\n const paused = watchableVelocity.value?.paused;\n playButton.style.display = paused ? \"\" : \"none\";\n pauseButton.style.display = !paused ? \"\" : \"none\";\n };\n context.registerDisposer(\n watchableVelocity.changed.add(updatePlayPause),\n );\n updatePlayPause();\n const velocityModel = new WatchableValue(0);\n velocityModel.changed.add(() => {\n const newValue = velocityModel.value;\n const velocity = watchableVelocity.value;\n if (velocity === undefined) return;\n if (velocity.velocity === newValue) return;\n watchableVelocity.value = { ...velocity, velocity: newValue };\n });\n const negateButton = makeIcon({\n text: \"±\",\n title: \"Negate velocity\",\n onClick: () => {\n velocityModel.value = -velocityModel.value;\n },\n });\n const velocityInputWidget = context.registerDisposer(\n new NumberInputWidget(velocityModel),\n );\n velocityInputWidget.inputElement.disabled = true;\n velocityInputWidget.element.insertBefore(\n negateButton,\n velocityInputWidget.element.firstChild,\n );\n velocityInputWidget.element.title =\n \"Velocity in coordinates per second\";\n const rateSpan = document.createElement(\"span\");\n rateSpan.textContent = \"/s\";\n velocityInputWidget.element.appendChild(rateSpan);\n parent.appendChild(velocityInputWidget.element);\n const trackableEnum = new TrackableEnum(\n VelocityBoundaryBehavior,\n VelocityBoundaryBehavior.STOP,\n );\n const watchableVelocityChanged = () => {\n trackableEnum.value =\n watchableVelocity.value?.atBoundary ??\n VelocityBoundaryBehavior.STOP;\n velocityModel.value = watchableVelocity.value?.velocity ?? 0;\n };\n watchableVelocityChanged();\n context.registerDisposer(\n watchableVelocity.changed.add(watchableVelocityChanged),\n );\n trackableEnum.changed.add(() => {\n const atBoundary = trackableEnum.value;\n const velocity = watchableVelocity.value;\n if (velocity === undefined) return;\n if (velocity.atBoundary === atBoundary) return;\n watchableVelocity.value = { ...velocity, atBoundary };\n });\n const selectWidget = new EnumSelectWidget(trackableEnum).element;\n parent.appendChild(selectWidget);\n selectWidget.title = \"Behavior when lower/upper bound is reached\";\n }),\n ).element,\n );\n content.appendChild(\n activation.registerDisposer(\n new CheckboxIcon(viewer.velocity.playbackEnabled(this.dimensionId), {\n svg: svg_video,\n enableTitle: \"Enable playback/velocity\",\n disableTitle: \"Disable playback/velocity\",\n backgroundScheme: \"dark\",\n }),\n ).element,\n );\n\n activation.bindAction(\n \"adjust-velocity-via-wheel\",\n (actionEvent) => {\n actionEvent.stopPropagation();\n const factor = getWheelZoomAmount(actionEvent.detail);\n viewer.velocity.multiplyVelocity(this.dimensionId, factor);\n },\n );\n activation.bindAction(\"toggle-playback\", (event) => {\n event.stopPropagation();\n viewer.velocity.togglePlayback(this.dimensionId);\n });\n }\n\n get description() {\n return `dim ${this.dimensionName}`;\n }\n\n dimensionIndex: number;\n dimensionName: string;\n\n constructor(\n public viewer: SupportsDimensionTool,\n public dimensionId: DimensionId,\n ) {\n super(viewer.toolBinder);\n const coordinateSpace = this.coordinateSpace.value;\n const i = (this.dimensionIndex = coordinateSpace.ids.indexOf(dimensionId));\n this.dimensionName = coordinateSpace.names[i];\n this.registerDisposer(\n this.coordinateSpace.changed.add(() => {\n const coordinateSpace = this.coordinateSpace.value;\n const i = (this.dimensionIndex =\n this.coordinateSpace.value.ids.indexOf(dimensionId));\n if (i === -1) {\n this.unbind();\n return;\n }\n const newName = coordinateSpace.names[i];\n if (this.dimensionName !== newName) {\n this.dimensionName = newName;\n this.changed.dispatch();\n }\n }),\n );\n }\n\n toJSON() {\n return {\n type: DIMENSION_TOOL_ID,\n dimension: this.dimensionName,\n };\n }\n}\n\nfunction makeDimensionTool(viewer: SupportsDimensionTool, obj: unknown) {\n const dimension = verifyObjectProperty(obj, \"dimension\", verifyString);\n const coordinateSpace = viewer.coordinateSpaceCombiner.combined.value;\n const dimensionIndex = coordinateSpace.names.indexOf(dimension);\n if (dimensionIndex === -1) {\n throw new Error(`Invalid dimension name: ${JSON.stringify(dimension)}`);\n }\n return new DimensionTool(viewer, coordinateSpace.ids[dimensionIndex]);\n}\n\nexport function registerDimensionToolForViewer(contextType: typeof Viewer) {\n registerTool(contextType, DIMENSION_TOOL_ID, (viewer, obj) =>\n makeDimensionTool(\n {\n position: viewer.position,\n velocity: viewer.velocity,\n coordinateSpaceCombiner:\n viewer.layerSpecification.coordinateSpaceCombiner,\n toolBinder: viewer.toolBinder,\n },\n obj,\n ),\n );\n}\n\nexport function registerDimensionToolForUserLayer(\n contextType: typeof UserLayer,\n) {\n registerTool(contextType, DIMENSION_TOOL_ID, (layer, obj) =>\n makeDimensionTool(\n {\n position: layer.localPosition,\n velocity: layer.localVelocity,\n coordinateSpaceCombiner: layer.localCoordinateSpaceCombiner,\n toolBinder: layer.toolBinder,\n },\n obj,\n ),\n );\n}\n\nexport function registerDimensionToolForLayerGroupViewer(\n contextType: typeof LayerGroupViewer,\n) {\n registerTool(contextType, DIMENSION_TOOL_ID, (layerGroupViewer, obj) =>\n makeDimensionTool(\n {\n position: layerGroupViewer.viewerNavigationState.position.value,\n velocity: layerGroupViewer.viewerNavigationState.velocity.velocity,\n coordinateSpaceCombiner:\n layerGroupViewer.layerSpecification.root.coordinateSpaceCombiner,\n toolBinder: layerGroupViewer.toolBinder,\n },\n obj,\n ),\n );\n}\n","/**\n * @license\n * Copyright 2024 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/transfer_function.css\";\n\nimport type { CoordinateSpaceCombiner } from \"#src/coordinate_transform.js\";\nimport type { DisplayContext } from \"#src/display_context.js\";\nimport { IndirectRenderedPanel } from \"#src/display_context.js\";\nimport type { UserLayer } from \"#src/layer/index.js\";\nimport { Position } from \"#src/navigation_state.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { makeCachedDerivedWatchableValue } from \"#src/trackable_value.js\";\nimport type { ToolActivation } from \"#src/ui/tool.js\";\nimport {\n arraysEqual,\n arraysEqualWithPredicate,\n findClosestMatchInSortedArray,\n} from \"#src/util/array.js\";\nimport { DATA_TYPE_SIGNED, DataType } from \"#src/util/data_type.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport {\n EventActionMap,\n registerActionListener,\n} from \"#src/util/event_action_map.js\";\nimport { kZeroVec4, vec3, vec4 } from \"#src/util/geom.js\";\nimport type { DataTypeInterval } from \"#src/util/lerp.js\";\nimport {\n computeInvlerp,\n computeLerp,\n defaultDataTypeRange,\n getIntervalBoundsEffectiveFraction,\n parseDataTypeValue,\n} from \"#src/util/lerp.js\";\nimport { MouseEventBinder } from \"#src/util/mouse_bindings.js\";\nimport { startRelativeMouseDrag } from \"#src/util/mouse_drag.js\";\nimport type { Uint64 } from \"#src/util/uint64.js\";\nimport { getWheelZoomAmount } from \"#src/util/wheel_zoom.js\";\nimport type { WatchableVisibilityPriority } from \"#src/visibility_priority/frontend.js\";\nimport type { Buffer } from \"#src/webgl/buffer.js\";\nimport { getMemoizedBuffer } from \"#src/webgl/buffer.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { HistogramSpecifications } from \"#src/webgl/empirical_cdf.js\";\nimport {\n defineInvlerpShaderFunction,\n enableLerpShaderFunction,\n} from \"#src/webgl/lerp.js\";\nimport {\n defineLineShader,\n drawLines,\n initializeLineShader,\n VERTICES_PER_LINE,\n} from \"#src/webgl/lines.js\";\nimport { drawQuads } from \"#src/webgl/quad.js\";\nimport { createGriddedRectangleArray } from \"#src/webgl/rectangle_grid_buffer.js\";\nimport type { ShaderCodePart, ShaderProgram } from \"#src/webgl/shader.js\";\nimport { ShaderBuilder } from \"#src/webgl/shader.js\";\nimport { getShaderType } from \"#src/webgl/shader_lib.js\";\nimport { setRawTextureParameters } from \"#src/webgl/texture.js\";\nimport { ColorWidget } from \"#src/widget/color.js\";\nimport {\n getUpdatedRangeAndWindowParameters,\n updateInputBoundValue,\n updateInputBoundWidth,\n createCDFLineShader,\n NUM_CDF_LINES,\n} from \"#src/widget/invlerp.js\";\nimport type {\n LayerControlFactory,\n LayerControlTool,\n} from \"#src/widget/layer_control.js\";\nimport { PositionWidget } from \"#src/widget/position_widget.js\";\nimport { Tab } from \"#src/widget/tab_view.js\";\n\nconst TRANSFER_FUNCTION_PANEL_SIZE = 512;\nexport const NUM_COLOR_CHANNELS = 4;\nconst POSITION_VALUES_PER_LINE = 4; // x1, y1, x2, y2\nconst CONTROL_POINT_X_GRAB_DISTANCE = 0.05;\nconst TRANSFER_FUNCTION_BORDER_WIDTH = 0.05;\n\nconst transferFunctionSamplerTextureUnit = Symbol(\n \"transferFunctionSamplerTexture\",\n);\nconst histogramSamplerTextureUnit = Symbol(\"histogramSamplerTexture\");\n\nconst defaultTransferFunctionSizes: Record = {\n [DataType.UINT8]: 256,\n [DataType.INT8]: 256,\n [DataType.UINT16]: 8192,\n [DataType.INT16]: 8192,\n [DataType.UINT32]: 8192,\n [DataType.INT32]: 8192,\n [DataType.UINT64]: 8192,\n [DataType.FLOAT32]: 8192,\n};\n\n/**\n * Options to update a lookup table texture with a direct lookup table\n */\nexport interface LookupTableTextureOptions {\n /** A lookup table is a series of color values (0 - 255) for each index in the transfer function texture\n */\n lookupTable: LookupTable;\n /** textureUnit to update with the new transfer function texture data */\n textureUnit: number | undefined;\n}\n\n/**\n * Options to update a transfer function texture using control points\n */\nexport interface ControlPointTextureOptions {\n /** controlPoints will be used to generate a lookup table as a first step */\n sortedControlPoints: SortedControlPoints;\n /** textureUnit to update with the new transfer function texture data */\n textureUnit: number | undefined;\n /** Data type of the control points */\n dataType: DataType;\n /** Lookup table number of elements*/\n lookupTableSize: number;\n}\n\nexport interface TransferFunctionParameters {\n sortedControlPoints: SortedControlPoints;\n window: DataTypeInterval;\n channel: number[];\n defaultColor: vec3;\n}\n\ninterface CanvasPosition {\n normalizedX: number;\n normalizedY: number;\n}\n\n/**\n * Transfer functions are controlled via a set of control points\n * with an input value and an output RGBA color (Uint8).\n * These control points are interpolated between to form a lookup table\n * which maps an input data value to an RGBA color.\n * Such a lookup table is used to form a texture, which can be sampled\n * from during rendering.\n */\nexport class ControlPoint {\n constructor(\n public inputValue: number | Uint64,\n public outputColor: vec4 = kZeroVec4,\n ) {}\n\n /** Convert the input value to a normalized value between 0 and 1 */\n normalizedInput(range: DataTypeInterval): number {\n return computeInvlerp(range, this.inputValue);\n }\n\n /** Convert the input value to an integer index into the transfer function lookup texture */\n transferFunctionIndex(\n dataRange: DataTypeInterval,\n transferFunctionSize: number,\n ): number {\n return Math.floor(\n this.normalizedInput(dataRange) * (transferFunctionSize - 1),\n );\n }\n interpolateColor(other: ControlPoint, t: number): vec4 {\n const outputColor = vec4.create();\n for (let i = 0; i < 4; ++i) {\n outputColor[i] = computeLerp(\n [this.outputColor[i], other.outputColor[i]],\n DataType.UINT8,\n t,\n ) as number;\n }\n return outputColor;\n }\n static copyFrom(other: ControlPoint) {\n const inputValue = other.inputValue;\n const outputColor = vec4.clone(other.outputColor);\n return new ControlPoint(inputValue, outputColor);\n }\n}\n\nexport class SortedControlPoints {\n public range: DataTypeInterval;\n constructor(\n public controlPoints: ControlPoint[] = [],\n public dataType: DataType,\n private autoComputeRange: boolean = true,\n ) {\n this.controlPoints = controlPoints;\n this.range = defaultDataTypeRange[dataType];\n this.sortAndComputeRange();\n }\n get length() {\n return this.controlPoints.length;\n }\n addPoint(controlPoint: ControlPoint) {\n const { inputValue, outputColor } = controlPoint;\n const exactMatch = this.controlPoints.findIndex(\n (point) => point.inputValue === inputValue,\n );\n if (exactMatch !== -1) {\n this.updatePointColor(exactMatch, outputColor);\n }\n const newPoint = new ControlPoint(inputValue, outputColor);\n this.controlPoints.push(newPoint);\n this.sortAndComputeRange();\n }\n removePoint(index: number) {\n this.controlPoints.splice(index, 1);\n this.computeRange();\n }\n updatePoint(index: number, controlPoint: ControlPoint): number {\n this.controlPoints[index] = controlPoint;\n const value = controlPoint.inputValue;\n const outputValue = controlPoint.outputColor;\n this.sortAndComputeRange();\n // Return the index of the original point after sorting\n for (let i = 0; i < this.controlPoints.length; ++i) {\n if (\n this.controlPoints[i].inputValue === value &&\n arraysEqual(this.controlPoints[i].outputColor, outputValue)\n ) {\n return i;\n }\n }\n return -1;\n }\n updatePointColor(index: number, color: vec4 | vec3) {\n let outputColor = vec4.create();\n if (color.length === 3) {\n const opacity = this.controlPoints[index].outputColor[3];\n outputColor = vec4.fromValues(color[0], color[1], color[2], opacity);\n } else {\n outputColor = vec4.clone(color as vec4);\n }\n this.controlPoints[index].outputColor = outputColor;\n }\n findNearestControlPointIndex(inputValue: number | Uint64) {\n const controlPoint = new ControlPoint(inputValue);\n const valueToFind = controlPoint.normalizedInput(this.range);\n return this.findNearestControlPointIndexByNormalizedInput(valueToFind);\n }\n findNearestControlPointIndexByNormalizedInput(normalizedInput: number) {\n return findClosestMatchInSortedArray(\n this.controlPoints.map((point) => point.normalizedInput(this.range)),\n normalizedInput,\n (a, b) => a - b,\n );\n }\n private sortAndComputeRange() {\n this.controlPoints.sort(\n (a, b) => a.normalizedInput(this.range) - b.normalizedInput(this.range),\n );\n this.computeRange();\n }\n private computeRange() {\n if (this.autoComputeRange) {\n if (this.controlPoints.length == 0) {\n this.range = defaultDataTypeRange[this.dataType];\n } else if (this.controlPoints.length === 1) {\n let rangeEnd = defaultDataTypeRange[this.dataType][1];\n if (\n this.dataType === DataType.FLOAT32 &&\n rangeEnd <= this.controlPoints[0].inputValue\n ) {\n rangeEnd = (this.controlPoints[0].inputValue as number) + 1;\n }\n this.range = [\n this.controlPoints[0].inputValue,\n rangeEnd,\n ] as DataTypeInterval;\n } else {\n this.range = [\n this.controlPoints[0].inputValue,\n this.controlPoints[this.controlPoints.length - 1].inputValue,\n ] as DataTypeInterval;\n }\n }\n if (this.range[0] === this.range[1]) {\n this.range = defaultDataTypeRange[this.dataType];\n }\n }\n copy() {\n const copy = new SortedControlPoints(\n [],\n this.dataType,\n this.autoComputeRange,\n );\n copy.range = this.range;\n copy.controlPoints = this.controlPoints.map((point) =>\n ControlPoint.copyFrom(point),\n );\n return copy;\n }\n}\n\nexport class LookupTable {\n outputValues: Uint8Array;\n constructor(public lookupTableSize: number) {\n this.outputValues = new Uint8Array(\n lookupTableSize * NUM_COLOR_CHANNELS,\n ).fill(0);\n }\n\n resize(newSize: number) {\n this.lookupTableSize = newSize;\n this.outputValues = new Uint8Array(newSize * NUM_COLOR_CHANNELS).fill(0);\n }\n\n /**\n * Fill a lookup table with color values between control points via linear interpolation.\n * Everything before the first point is transparent,\n * everything after the last point has the color of the last point.\n *\n * @param controlPoints The control points to interpolate between\n * @param dataRange The range of the input data space\n */\n updateFromControlPoints(\n sortedControlPoints: SortedControlPoints,\n window: DataTypeInterval | undefined = undefined,\n ) {\n const range = window ? window : sortedControlPoints.range;\n const { controlPoints } = sortedControlPoints;\n const out = this.outputValues;\n const size = this.lookupTableSize;\n function addLookupValue(index: number, color: vec4) {\n out[index] = color[0];\n out[index + 1] = color[1];\n out[index + 2] = color[2];\n out[index + 3] = color[3];\n }\n /**\n * Convert the control point input value to an index in the transfer function lookup table\n */\n function toTransferFunctionSpace(controlPoint: ControlPoint) {\n return controlPoint.transferFunctionIndex(range, size);\n }\n\n // If no control points - return all transparent\n if (controlPoints.length === 0) {\n out.fill(0);\n return;\n }\n\n // If first control point not at 0 - fill in transparent values\n // up to the first point\n const firstInputValue = toTransferFunctionSpace(controlPoints[0]);\n if (firstInputValue > 0) {\n const transparent = vec4.fromValues(0, 0, 0, 0);\n for (let i = 0; i < firstInputValue; ++i) {\n const index = i * NUM_COLOR_CHANNELS;\n addLookupValue(index, transparent);\n }\n }\n\n // Interpolate between control points and fill to end with last color\n let controlPointIndex = 0;\n for (let i = firstInputValue; i < size; ++i) {\n const currentPoint = controlPoints[controlPointIndex];\n const lookupIndex = i * NUM_COLOR_CHANNELS;\n if (controlPointIndex === controlPoints.length - 1) {\n addLookupValue(lookupIndex, currentPoint.outputColor);\n } else {\n const nextPoint = controlPoints[controlPointIndex + 1];\n const currentPointIndex = toTransferFunctionSpace(currentPoint);\n const nextPointIndex = toTransferFunctionSpace(nextPoint);\n const t =\n (i - currentPointIndex) / (nextPointIndex - currentPointIndex);\n const lerpedColor = currentPoint.interpolateColor(nextPoint, t);\n addLookupValue(lookupIndex, lerpedColor);\n if (i >= nextPointIndex) {\n controlPointIndex++;\n }\n }\n }\n }\n static equal(a: LookupTable, b: LookupTable) {\n return arraysEqual(a.outputValues, b.outputValues);\n }\n copy() {\n const copy = new LookupTable(this.lookupTableSize);\n copy.outputValues.set(this.outputValues);\n return copy;\n }\n}\n\n/**\n * Handles a linked lookup table and control points for a transfer function.\n */\nexport class TransferFunction extends RefCounted {\n lookupTable: LookupTable;\n constructor(\n public dataType: DataType,\n public trackable: WatchableValueInterface,\n size: number = defaultTransferFunctionSizes[dataType],\n ) {\n super();\n this.lookupTable = new LookupTable(size);\n this.updateLookupTable();\n }\n get sortedControlPoints() {\n return this.trackable.value.sortedControlPoints;\n }\n get range() {\n return this.sortedControlPoints.range;\n }\n get size() {\n return this.lookupTable.lookupTableSize;\n }\n updateLookupTable(window: DataTypeInterval | undefined = undefined) {\n this.lookupTable.updateFromControlPoints(this.sortedControlPoints, window);\n }\n addPoint(controlPoint: ControlPoint) {\n this.sortedControlPoints.addPoint(controlPoint);\n }\n updatePoint(index: number, controlPoint: ControlPoint): number {\n return this.sortedControlPoints.updatePoint(index, controlPoint);\n }\n removePoint(index: number) {\n this.sortedControlPoints.removePoint(index);\n }\n updatePointColor(index: number, color: vec4 | vec3) {\n this.sortedControlPoints.updatePointColor(index, color);\n }\n findNearestControlPointIndex(\n normalizedInputValue: number,\n dataWindow: DataTypeInterval,\n ) {\n const absoluteValue = computeLerp(\n dataWindow,\n this.dataType,\n normalizedInputValue,\n );\n return this.sortedControlPoints.findNearestControlPointIndex(absoluteValue);\n }\n}\n\nabstract class BaseLookupTexture extends RefCounted {\n texture: WebGLTexture | null = null;\n protected width: number;\n protected height = 1;\n protected priorOptions:\n | LookupTableTextureOptions\n | ControlPointTextureOptions\n | undefined = undefined;\n constructor(public gl: GL | null) {\n super();\n }\n /**\n * Compare the existing options to the new options to determine if the texture needs to be updated\n */\n abstract optionsEqual(\n newOptions: LookupTableTextureOptions | ControlPointTextureOptions,\n ): boolean;\n abstract createLookupTable(\n options: LookupTableTextureOptions | ControlPointTextureOptions,\n ): LookupTable;\n abstract setOptions(\n options: LookupTableTextureOptions | ControlPointTextureOptions,\n ): void;\n updateAndActivate(\n options: LookupTableTextureOptions | ControlPointTextureOptions,\n ) {\n const { gl } = this;\n if (gl === null) return;\n let { texture } = this;\n\n function activateAndBindTexture(gl: GL, textureUnit: number | undefined) {\n if (textureUnit === undefined) {\n throw new Error(\n \"Texture unit must be defined for transfer function texture\",\n );\n }\n gl.activeTexture(WebGL2RenderingContext.TEXTURE0 + textureUnit);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, texture);\n }\n // If the texture is already up to date, just bind and activate it\n if (texture !== null && this.optionsEqual(options)) {\n activateAndBindTexture(gl, options.textureUnit);\n return this.width * this.height;\n }\n // If the texture has not been created yet, create it\n if (texture === null) {\n texture = this.texture = gl.createTexture();\n }\n // Update the texture\n activateAndBindTexture(gl, options.textureUnit);\n setRawTextureParameters(gl);\n const lookupTable = this.createLookupTable(options);\n\n gl.texImage2D(\n WebGL2RenderingContext.TEXTURE_2D,\n 0,\n WebGL2RenderingContext.RGBA,\n this.width,\n this.height,\n 0,\n WebGL2RenderingContext.RGBA,\n WebGL2RenderingContext.UNSIGNED_BYTE,\n lookupTable.outputValues,\n );\n\n // Update the prior options to the current options for future comparisons\n this.setOptions(options);\n return this.width * this.height;\n }\n setTextureWidthAndHeightFromSize(size: number) {\n this.width = size;\n }\n disposed() {\n this.gl?.deleteTexture(this.texture);\n this.texture = null;\n this.priorOptions = undefined;\n super.disposed();\n }\n}\n\n/**\n * Represent the underlying transfer function lookup table as a texture\n */\nclass DirectLookupTableTexture extends BaseLookupTexture {\n texture: WebGLTexture | null = null;\n protected priorOptions: LookupTableTextureOptions | undefined = undefined;\n\n constructor(public gl: GL | null) {\n super(gl);\n }\n optionsEqual(newOptions: LookupTableTextureOptions) {\n const existingOptions = this.priorOptions;\n if (existingOptions === undefined) return false;\n const lookupTableEqual = LookupTable.equal(\n existingOptions.lookupTable,\n newOptions.lookupTable,\n );\n const textureUnitEqual =\n existingOptions.textureUnit === newOptions.textureUnit;\n return lookupTableEqual && textureUnitEqual;\n }\n createLookupTable(options: LookupTableTextureOptions): LookupTable {\n this.setTextureWidthAndHeightFromSize(options.lookupTable.lookupTableSize);\n return options.lookupTable;\n }\n setOptions(options: LookupTableTextureOptions) {\n this.priorOptions = {\n ...options,\n lookupTable: options.lookupTable.copy(),\n };\n }\n}\n\nexport class ControlPointTexture extends BaseLookupTexture {\n protected priorOptions: ControlPointTextureOptions | undefined;\n constructor(public gl: GL | null) {\n super(gl);\n }\n optionsEqual(newOptions: ControlPointTextureOptions): boolean {\n const existingOptions = this.priorOptions;\n if (existingOptions === undefined) return false;\n const controlPointsEqual = arraysEqualWithPredicate(\n existingOptions.sortedControlPoints.controlPoints,\n newOptions.sortedControlPoints.controlPoints,\n (a, b) =>\n a.inputValue === b.inputValue &&\n arraysEqual(a.outputColor, b.outputColor),\n );\n const textureUnitEqual =\n existingOptions.textureUnit === newOptions.textureUnit;\n const dataTypeEqual = existingOptions.dataType === newOptions.dataType;\n return controlPointsEqual && textureUnitEqual && dataTypeEqual;\n }\n setOptions(options: ControlPointTextureOptions) {\n this.priorOptions = {\n ...options,\n sortedControlPoints: options.sortedControlPoints.copy(),\n };\n }\n createLookupTable(options: ControlPointTextureOptions): LookupTable {\n const lookupTableSize = this.ensureTextureSize(options.lookupTableSize);\n if (lookupTableSize === undefined) return new LookupTable(0);\n this.setTextureWidthAndHeightFromSize(lookupTableSize);\n const lookupTable = new LookupTable(lookupTableSize);\n const sortedControlPoints = options.sortedControlPoints;\n lookupTable.updateFromControlPoints(sortedControlPoints);\n return lookupTable;\n }\n ensureTextureSize(size: number) {\n const gl = this.gl;\n if (gl === null) return;\n const maxTextureSize = gl.getParameter(gl.MAX_TEXTURE_SIZE);\n const tableTextureSize = Math.min(size, maxTextureSize);\n return tableTextureSize;\n }\n}\n\n/**\n * Display the UI canvas for the transfer function widget and\n * handle shader updates for elements of the canvas\n */\nclass TransferFunctionPanel extends IndirectRenderedPanel {\n texture: DirectLookupTableTexture;\n private textureVertexBuffer: Buffer;\n private textureVertexBufferArray: Float32Array;\n private controlPointsVertexBuffer: Buffer;\n private controlPointsPositionArray = new Float32Array();\n private controlPointsColorBuffer: Buffer;\n private controlPointsColorArray = new Float32Array();\n private linePositionBuffer: Buffer;\n private linePositionArray = new Float32Array();\n get drawOrder() {\n return 1;\n }\n transferFunction = this.registerDisposer(\n new TransferFunction(\n this.parent.dataType,\n this.parent.trackable,\n TRANSFER_FUNCTION_PANEL_SIZE,\n ),\n );\n controller = this.registerDisposer(\n new TransferFunctionController(\n this.element,\n this.parent.dataType,\n this.transferFunction,\n () => this.parent.trackable.value,\n (value: TransferFunctionParameters) => {\n this.parent.trackable.value = value;\n },\n ),\n );\n private dataValuesBuffer = this.registerDisposer(\n getMemoizedBuffer(this.gl, WebGL2RenderingContext.ARRAY_BUFFER, () => {\n const array = new Uint8Array(NUM_CDF_LINES * VERTICES_PER_LINE);\n for (let i = 0; i < NUM_CDF_LINES; ++i) {\n for (let j = 0; j < VERTICES_PER_LINE; ++j) {\n array[i * VERTICES_PER_LINE + j] = i;\n }\n }\n return array;\n }),\n ).value;\n\n constructor(public parent: TransferFunctionWidget) {\n super(parent.display, document.createElement(\"div\"), parent.visibility);\n const { element, gl } = this;\n element.classList.add(\"neuroglancer-transfer-function-panel\");\n this.textureVertexBufferArray = createGriddedRectangleArray(\n TRANSFER_FUNCTION_PANEL_SIZE,\n );\n this.texture = this.registerDisposer(new DirectLookupTableTexture(gl));\n\n function createBuffer(dataArray: Float32Array) {\n return getMemoizedBuffer(\n gl,\n WebGL2RenderingContext.ARRAY_BUFFER,\n () => dataArray,\n ).value;\n }\n this.textureVertexBuffer = this.registerDisposer(\n createBuffer(this.textureVertexBufferArray),\n );\n this.controlPointsVertexBuffer = this.registerDisposer(\n createBuffer(this.controlPointsPositionArray),\n );\n this.controlPointsColorBuffer = this.registerDisposer(\n createBuffer(this.controlPointsColorArray),\n );\n this.linePositionBuffer = this.registerDisposer(\n createBuffer(this.linePositionArray),\n );\n }\n\n updateTransferFunctionPointsAndLines() {\n // Normalize position to [-1, 1] for shader (x axis)\n const window = this.parent.trackable.value.window;\n function normalizeInput(input: number | Uint64) {\n const lerpedInput = computeInvlerp(window, input);\n return lerpedInput * 2 - 1;\n }\n // Normalize opacity to [-1, 1] for shader (y axis)\n function normalizeOpacity(opacity: number) {\n return (opacity / 255) * 2 - 1;\n }\n // Normalize color to [0, 1] for shader (color channels)\n function normalizeColor(colorComponent: number) {\n return colorComponent / 255;\n }\n function addLine(\n array: Float32Array,\n index: number,\n positions: vec4,\n ): number {\n for (let i = 0; i < VERTICES_PER_LINE; ++i) {\n array[index++] = positions[0];\n array[index++] = positions[1];\n array[index++] = positions[2];\n array[index++] = positions[3];\n }\n return index;\n }\n function isInWindow(normalizedInput: number) {\n return normalizedInput >= -1 && normalizedInput <= 1;\n }\n\n const { transferFunction } = this;\n const { controlPoints } =\n transferFunction.trackable.value.sortedControlPoints;\n let numLines = Math.max(controlPoints.length - 1, 0);\n const colorChannels = NUM_COLOR_CHANNELS - 1; // ignore alpha\n const colorArray = new Float32Array(controlPoints.length * colorChannels);\n const positionArray = new Float32Array(controlPoints.length * 2);\n let linePositionArrayIndex = 0;\n let lineFromLeftEdge = null;\n let lineToRightEdge = null;\n // Map all control points to normalized values for the shader\n const normalizedControlPoints = controlPoints.map((point) => {\n const input = normalizeInput(point.inputValue);\n const output = normalizeOpacity(point.outputColor[3]);\n return { input, output };\n });\n\n // Create start and end lines if there are any control points\n if (controlPoints.length > 0) {\n // Try to find the first and last point in the window\n\n const {\n firstPointIndexInWindow,\n lastPointIndexInWindow,\n pointClosestToLeftEdge,\n pointClosestToRightEdge,\n } = findPointsNearWindowBounds();\n // If there are no points in the window, check if everything is left or right of the window\n // Draw a single line from the left edge to the right edge if all points are left of the window\n if (firstPointIndexInWindow === null) {\n const allPointsLeftOfWindow =\n normalizedControlPoints[controlPoints.length - 1].input < -1;\n const allPointsRightOfWindow = normalizedControlPoints[0].input > 1;\n if (allPointsLeftOfWindow) {\n drawHorizontalLineFromPointOutsideLeftWindow();\n }\n // There are no points in the window, but points on either side\n // Draw lines from the leftmost and rightmost points starting\n // from the left edge and ending at the right edge via interpolation\n else if (!allPointsRightOfWindow && controlPoints.length > 1) {\n drawLineBetweenPointsBothOutsideWindow(\n pointClosestToLeftEdge,\n pointClosestToRightEdge,\n );\n }\n } else {\n const firstPointInWindow =\n normalizedControlPoints[firstPointIndexInWindow];\n if (firstPointInWindow.input > -1) {\n // If there is a value to the left, draw a line from the point outside the window to the first point in the window\n if (firstPointIndexInWindow > 0) {\n drawLineBetweenPointInWindowAndLeftPointOutsideWindow(\n firstPointIndexInWindow,\n firstPointInWindow,\n );\n }\n // If the first point in the window is the leftmost point, draw a 0 line up to the point\n else {\n lineFromLeftEdge = vec4.fromValues(\n firstPointInWindow.input,\n -1,\n firstPointInWindow.input,\n firstPointInWindow.output,\n );\n }\n numLines += 1;\n }\n // Need to draw a line from the last control point in the window to the right edge\n const lastPointInWindow =\n normalizedControlPoints[lastPointIndexInWindow!];\n if (lastPointInWindow.input < 1) {\n // If there is a value to the right, draw a line from the last point in the window to the point outside the window\n if (lastPointIndexInWindow! < controlPoints.length - 1) {\n drawLineBetweenPointInWindowAndRightPointOutsideWindow(\n lastPointIndexInWindow,\n lastPointInWindow,\n );\n }\n // If the last point in the window is the rightmost point, draw a line from the point to the right edge\n else {\n lineToRightEdge = vec4.fromValues(\n lastPointInWindow.input,\n lastPointInWindow.output,\n 1,\n lastPointInWindow.output,\n );\n }\n numLines += 1;\n }\n }\n }\n\n const lines: vec4[] = [];\n // Update points and draw lines between control points\n for (let i = 0; i < controlPoints.length; ++i) {\n const colorIndex = i * colorChannels;\n const positionIndex = i * 2;\n const inputValue = normalizedControlPoints[i].input;\n const outputValue = normalizedControlPoints[i].output;\n const { outputColor } = controlPoints[i];\n colorArray[colorIndex] = normalizeColor(outputColor[0]);\n colorArray[colorIndex + 1] = normalizeColor(outputColor[1]);\n colorArray[colorIndex + 2] = normalizeColor(outputColor[2]);\n positionArray[positionIndex] = inputValue;\n positionArray[positionIndex + 1] = outputValue;\n\n // Don't create a line for the last point\n if (i === controlPoints.length - 1) break;\n if (!(isInWindow(inputValue) && isInWindow(outputValue))) continue;\n numLines += 1;\n const lineBetweenPoints = vec4.fromValues(\n inputValue,\n outputValue,\n normalizedControlPoints[i + 1].input,\n normalizedControlPoints[i + 1].output,\n );\n lines.push(lineBetweenPoints);\n }\n\n // Create and fill the line position array\n const linePositionArray = new Float32Array(\n numLines * POSITION_VALUES_PER_LINE * VERTICES_PER_LINE,\n );\n\n if (lineFromLeftEdge !== null) {\n linePositionArrayIndex = addLine(\n linePositionArray,\n linePositionArrayIndex,\n lineFromLeftEdge,\n );\n }\n\n for (const lineBetweenPoints of lines) {\n linePositionArrayIndex = addLine(\n linePositionArray,\n linePositionArrayIndex,\n lineBetweenPoints,\n );\n }\n\n // Draw a horizontal line out from the last point\n if (lineToRightEdge !== null) {\n addLine(linePositionArray, linePositionArrayIndex, lineToRightEdge);\n }\n\n // Update buffers\n this.controlPointsColorArray = colorArray;\n this.controlPointsPositionArray = positionArray;\n this.linePositionArray = linePositionArray;\n this.controlPointsVertexBuffer.setData(this.controlPointsPositionArray);\n this.controlPointsColorBuffer.setData(this.controlPointsColorArray);\n this.linePositionBuffer.setData(this.linePositionArray);\n\n function drawLineBetweenPointInWindowAndRightPointOutsideWindow(\n lastPointIndexInWindow: number | null,\n lastPointInWindow: { input: number; output: number },\n ) {\n const pointAfterWindow =\n normalizedControlPoints[lastPointIndexInWindow! + 1];\n const interpFactor = computeInvlerp(\n [lastPointInWindow.input, pointAfterWindow.input],\n 1,\n );\n const lineEndY = computeLerp(\n [lastPointInWindow.output, pointAfterWindow.output],\n DataType.FLOAT32,\n interpFactor,\n ) as number;\n lineToRightEdge = vec4.fromValues(\n lastPointInWindow.input,\n lastPointInWindow.output,\n 1,\n lineEndY,\n );\n }\n\n function drawLineBetweenPointInWindowAndLeftPointOutsideWindow(\n firstPointIndexInWindow: number,\n firstPointInWindow: { input: number; output: number },\n ) {\n const pointBeforeWindow =\n normalizedControlPoints[firstPointIndexInWindow - 1];\n const interpFactor = computeInvlerp(\n [pointBeforeWindow.input, firstPointInWindow.input],\n -1,\n );\n const lineStartY = computeLerp(\n [pointBeforeWindow.output, firstPointInWindow.output],\n DataType.FLOAT32,\n interpFactor,\n ) as number;\n lineFromLeftEdge = vec4.fromValues(\n -1,\n lineStartY,\n firstPointInWindow.input,\n firstPointInWindow.output,\n );\n }\n\n function drawLineBetweenPointsBothOutsideWindow(\n pointClosestToLeftEdge: { input: number; output: number } | null,\n pointClosestToRightEdge: { input: number; output: number } | null,\n ) {\n numLines += 1;\n if (pointClosestToLeftEdge === null || pointClosestToRightEdge === null) {\n throw new Error(\n \"Could not find points closest to the left and right edges\",\n );\n }\n const leftInterpFactor = computeInvlerp(\n [pointClosestToLeftEdge.input, pointClosestToRightEdge.input],\n -1,\n );\n const rightInterpFactor = computeInvlerp(\n [pointClosestToLeftEdge.input, pointClosestToRightEdge.input],\n 1,\n );\n const leftLineY = computeLerp(\n [pointClosestToLeftEdge.output, pointClosestToRightEdge.output],\n DataType.FLOAT32,\n leftInterpFactor,\n ) as number;\n const rightLineY = computeLerp(\n [pointClosestToLeftEdge.output, pointClosestToRightEdge.output],\n DataType.FLOAT32,\n rightInterpFactor,\n ) as number;\n lineFromLeftEdge = vec4.fromValues(-1, leftLineY, 1, rightLineY);\n }\n\n function findPointsNearWindowBounds() {\n let firstPointIndexInWindow = null;\n let lastPointIndexInWindow = null;\n let pointClosestToLeftEdge = null;\n let pointClosestToRightEdge = null;\n for (let i = 0; i < controlPoints.length; ++i) {\n const point = normalizedControlPoints[i];\n if (isInWindow(point.input)) {\n firstPointIndexInWindow = firstPointIndexInWindow ?? i;\n lastPointIndexInWindow = i;\n }\n if (point.input < -1) {\n pointClosestToLeftEdge = point;\n } else if (point.input > 1) {\n pointClosestToRightEdge = point;\n break;\n }\n }\n return {\n firstPointIndexInWindow,\n lastPointIndexInWindow,\n pointClosestToLeftEdge,\n pointClosestToRightEdge,\n };\n }\n\n function drawHorizontalLineFromPointOutsideLeftWindow() {\n const indexOfReferencePoint = controlPoints.length - 1;\n numLines += 1;\n const referenceOpacity =\n normalizedControlPoints[indexOfReferencePoint].output;\n lineFromLeftEdge = vec4.fromValues(\n -1,\n referenceOpacity,\n 1,\n referenceOpacity,\n );\n }\n }\n\n private histogramLineShader = this.registerDisposer(\n (() => createCDFLineShader(this.gl, histogramSamplerTextureUnit))(),\n );\n\n private transferFunctionLineShader = this.registerDisposer(\n (() => {\n const builder = new ShaderBuilder(this.gl);\n defineLineShader(builder);\n builder.addAttribute(\"vec4\", \"aLineStartEnd\");\n builder.addOutputBuffer(\"vec4\", \"out_color\", 0);\n builder.addVarying(\"float\", \"vColor\");\n builder.setVertexMain(`\nvec4 start = vec4(aLineStartEnd[0], aLineStartEnd[1], 0.0, 1.0);\nvec4 end = vec4(aLineStartEnd[2], aLineStartEnd[3], 0.0, 1.0);\nemitLine(start, end, 1.0);\n`);\n builder.setFragmentMain(`\nout_color = vec4(0.35, 0.35, 0.35, getLineAlpha());\n`);\n return builder.build();\n })(),\n );\n\n private transferFunctionShader = this.registerDisposer(\n (() => {\n const builder = new ShaderBuilder(this.gl);\n builder.addAttribute(\"vec2\", \"aVertexPosition\");\n builder.addVarying(\"vec2\", \"vTexCoord\");\n builder.addOutputBuffer(\"vec4\", \"out_color\", 0);\n builder.addTextureSampler(\n \"sampler2D\",\n \"uSampler\",\n transferFunctionSamplerTextureUnit,\n );\n builder.addUniform(\"float\", \"uTransferFunctionEnd\");\n builder.setVertexMain(`\ngl_Position = vec4(aVertexPosition, 0.0, 1.0);\nvTexCoord = (aVertexPosition + 1.0) / 2.0;\n`);\n builder.setFragmentMain(`\nivec2 texel = ivec2(floor(vTexCoord.x * uTransferFunctionEnd), 0);\nout_color = texelFetch(uSampler, texel, 0);\n`);\n return builder.build();\n })(),\n );\n\n private controlPointsShader = this.registerDisposer(\n (() => {\n const builder = new ShaderBuilder(this.gl);\n builder.addAttribute(\"vec2\", \"aVertexPosition\");\n builder.addAttribute(\"vec3\", \"aVertexColor\");\n builder.addVarying(\"vec3\", \"vColor\");\n builder.addOutputBuffer(\"vec4\", \"out_color\", 0);\n builder.setVertexMain(`\ngl_Position = vec4(aVertexPosition, 0.0, 1.0);\ngl_PointSize = 14.0;\nvColor = aVertexColor;\n`);\n // Draw control points as circles with a border\n // The border is white if the color is dark, black if the color is light\n builder.setFragmentMain(`\nfloat vColorSum = vColor.r + vColor.g + vColor.b;\nvec3 bordercolor = vec3(0.0, 0.0, 0.0);\nif (vColorSum < 0.4) {\n bordercolor = vec3(1.0, 1.0, 1.0);\n}\nfloat dist = distance(gl_PointCoord, vec2(0.5, 0.5));\nfloat alpha = smoothstep(0.25, 0.4, dist);\nvec4 tempColor = vec4(mix(vColor, bordercolor, alpha), 1.0);\nalpha = 1.0 - smoothstep(0.4, 0.5, dist);\nout_color = tempColor * alpha;\n`);\n return builder.build();\n })(),\n );\n\n drawIndirect() {\n const {\n transferFunctionLineShader,\n gl,\n transferFunctionShader,\n controlPointsShader,\n histogramLineShader: lineShader,\n } = this;\n this.setGLLogicalViewport();\n gl.clearColor(0.0, 0.0, 0.0, 0.0);\n gl.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT);\n gl.enable(WebGL2RenderingContext.BLEND);\n gl.blendFunc(\n WebGL2RenderingContext.SRC_ALPHA,\n WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA,\n );\n gl.disable(WebGL2RenderingContext.DEPTH_TEST);\n gl.disable(WebGL2RenderingContext.STENCIL_TEST);\n {\n // Draw transfer function texture\n transferFunctionShader.bind();\n const aVertexPosition =\n transferFunctionShader.attribute(\"aVertexPosition\");\n gl.uniform1f(\n transferFunctionShader.uniform(\"uTransferFunctionEnd\"),\n TRANSFER_FUNCTION_PANEL_SIZE - 1,\n );\n this.textureVertexBuffer.bindToVertexAttrib(\n aVertexPosition,\n /*components=*/ 2,\n /*attributeType=*/ WebGL2RenderingContext.FLOAT,\n );\n const textureUnit = transferFunctionShader.textureUnit(\n transferFunctionSamplerTextureUnit,\n );\n this.texture.updateAndActivate({\n lookupTable: this.transferFunction.lookupTable,\n textureUnit,\n });\n drawQuads(this.gl, TRANSFER_FUNCTION_PANEL_SIZE, 1);\n gl.disableVertexAttribArray(aVertexPosition);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, null);\n }\n // Draw CDF lines\n if (this.parent.histogramSpecifications.producerVisibility.visible) {\n const { renderViewport } = this;\n lineShader.bind();\n initializeLineShader(\n lineShader,\n {\n width: renderViewport.logicalWidth,\n height: renderViewport.logicalHeight,\n },\n /*featherWidthInPixels=*/ 1.0,\n );\n const histogramTextureUnit = lineShader.textureUnit(\n histogramSamplerTextureUnit,\n );\n gl.uniform1f(\n lineShader.uniform(\"uBoundsFraction\"),\n getIntervalBoundsEffectiveFraction(\n this.parent.dataType,\n this.parent.trackable.value.window,\n ),\n );\n gl.activeTexture(WebGL2RenderingContext.TEXTURE0 + histogramTextureUnit);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, this.parent.texture);\n setRawTextureParameters(gl);\n const aDataValue = lineShader.attribute(\"aDataValue\");\n this.dataValuesBuffer.bindToVertexAttribI(\n aDataValue,\n /*componentsPerVertexAttribute=*/ 1,\n /*attributeType=*/ WebGL2RenderingContext.UNSIGNED_BYTE,\n );\n drawLines(gl, /*linesPerInstance=*/ NUM_CDF_LINES, /*numInstances=*/ 1);\n gl.disableVertexAttribArray(aDataValue);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, null);\n }\n\n // Draw lines and control points on top of transfer function - if there are any\n if (this.controlPointsPositionArray.length > 0) {\n const { renderViewport } = this;\n\n // Draw transfer function lerp indicator lines\n transferFunctionLineShader.bind();\n const aLineStartEnd =\n transferFunctionLineShader.attribute(\"aLineStartEnd\");\n this.linePositionBuffer.bindToVertexAttrib(\n aLineStartEnd,\n /*components=*/ 4,\n /*attributeType=*/ WebGL2RenderingContext.FLOAT,\n );\n initializeLineShader(\n transferFunctionLineShader,\n {\n width: renderViewport.logicalWidth,\n height: renderViewport.logicalHeight,\n },\n /*featherWidthInPixels=*/ 1,\n );\n drawLines(\n gl,\n this.linePositionArray.length /\n (VERTICES_PER_LINE * POSITION_VALUES_PER_LINE),\n 1,\n );\n gl.disableVertexAttribArray(aLineStartEnd);\n\n // Draw control points of the transfer function\n controlPointsShader.bind();\n const aVertexPosition = controlPointsShader.attribute(\"aVertexPosition\");\n this.controlPointsVertexBuffer.bindToVertexAttrib(\n aVertexPosition,\n /*components=*/ 2,\n /*attributeType=*/ WebGL2RenderingContext.FLOAT,\n );\n const aVertexColor = controlPointsShader.attribute(\"aVertexColor\");\n this.controlPointsColorBuffer.bindToVertexAttrib(\n aVertexColor,\n /*components=*/ 3,\n /*attributeType=*/ WebGL2RenderingContext.FLOAT,\n );\n gl.drawArrays(gl.POINTS, 0, this.controlPointsPositionArray.length / 2);\n gl.disableVertexAttribArray(aVertexPosition);\n gl.disableVertexAttribArray(aVertexColor);\n }\n gl.disable(WebGL2RenderingContext.BLEND);\n }\n update() {\n this.transferFunction.updateLookupTable(this.parent.trackable.value.window);\n this.updateTransferFunctionPointsAndLines();\n }\n isReady() {\n return true;\n }\n}\n\n/**\n * Create the bounds on the UI window inputs for the transfer function widget\n */\nfunction createWindowBoundInputs(\n dataType: DataType,\n model: WatchableValueInterface,\n) {\n function createWindowBoundInput(endpoint: number): HTMLInputElement {\n const e = document.createElement(\"input\");\n e.addEventListener(\"focus\", () => {\n e.select();\n });\n e.classList.add(\"neuroglancer-transfer-function-widget-bound\");\n e.type = \"text\";\n e.spellcheck = false;\n e.autocomplete = \"off\";\n e.title = `${\n endpoint === 0 ? \"Lower\" : \"Upper\"\n } window for transfer function`;\n return e;\n }\n\n const container = document.createElement(\"div\");\n container.classList.add(\"neuroglancer-transfer-function-window-bounds\");\n const inputs = [createWindowBoundInput(0), createWindowBoundInput(1)];\n for (let endpointIndex = 0; endpointIndex < 2; ++endpointIndex) {\n const input = inputs[endpointIndex];\n input.addEventListener(\"input\", () => {\n updateInputBoundWidth(input);\n });\n input.addEventListener(\"change\", () => {\n const existingBounds = model.value.window;\n const intervals = { range: existingBounds, window: existingBounds };\n try {\n const value = parseDataTypeValue(dataType, input.value);\n const window = getUpdatedRangeAndWindowParameters(\n intervals,\n \"window\",\n endpointIndex,\n value,\n /*fitRangeInWindow=*/ true,\n ).window;\n if (window[0] === window[1]) {\n throw new Error(\"Window bounds cannot be equal\");\n }\n model.value = { ...model.value, window };\n } catch {\n updateInputBoundValue(input, existingBounds[endpointIndex]);\n }\n });\n }\n container.appendChild(inputs[0]);\n container.appendChild(inputs[1]);\n return {\n container,\n inputs,\n };\n}\n\nconst inputEventMap = EventActionMap.fromObject({\n \"shift?+mousedown0\": { action: \"add-or-drag-point\" },\n \"shift+dblclick0\": { action: \"remove-point\" },\n \"shift?+mousedown2\": { action: \"change-point-color\" },\n \"shift?+wheel\": { action: \"zoom-via-wheel\" },\n});\n\n/**\n * Controller for the transfer function widget. Handles mouse events and updates to the model.\n */\nclass TransferFunctionController extends RefCounted {\n private currentGrabbedControlPointIndex = -1;\n constructor(\n public element: HTMLElement,\n public dataType: DataType,\n private transferFunction: TransferFunction,\n public getModel: () => TransferFunctionParameters,\n public setModel: (value: TransferFunctionParameters) => void,\n ) {\n super();\n element.title = inputEventMap.describe();\n this.registerDisposer(new MouseEventBinder(element, inputEventMap));\n registerActionListener(\n element,\n \"add-or-drag-point\",\n (actionEvent) => {\n const mouseEvent = actionEvent.detail;\n this.updateValue(this.addControlPoint(mouseEvent));\n startRelativeMouseDrag(mouseEvent, (newEvent: MouseEvent) => {\n this.updateValue(this.moveControlPoint(newEvent));\n });\n },\n );\n registerActionListener(\n element,\n \"remove-point\",\n (actionEvent) => {\n const mouseEvent = actionEvent.detail;\n const nearestIndex = this.findControlPointIfNearCursor(mouseEvent);\n if (nearestIndex !== -1) {\n this.transferFunction.removePoint(nearestIndex);\n this.updateValue({\n ...this.getModel(),\n sortedControlPoints:\n this.transferFunction.trackable.value.sortedControlPoints,\n });\n }\n },\n );\n registerActionListener(\n element,\n \"change-point-color\",\n (actionEvent) => {\n const mouseEvent = actionEvent.detail;\n const nearestIndex = this.findControlPointIfNearCursor(mouseEvent);\n if (nearestIndex !== -1) {\n const color = this.transferFunction.trackable.value.defaultColor;\n const colorInAbsoluteValue =\n this.convertPanelSpaceColorToAbsoluteValue(color);\n this.transferFunction.updatePointColor(\n nearestIndex,\n colorInAbsoluteValue,\n );\n this.updateValue({\n ...this.getModel(),\n sortedControlPoints:\n this.transferFunction.trackable.value.sortedControlPoints,\n });\n }\n },\n );\n registerActionListener(\n element,\n \"zoom-via-wheel\",\n (actionEvent) => {\n const wheelEvent = actionEvent.detail;\n const zoomAmount = getWheelZoomAmount(wheelEvent);\n const relativeX = this.getTargetFraction(wheelEvent);\n const { dataType } = this;\n const model = this.getModel();\n const newLower = computeLerp(\n model.window,\n dataType,\n relativeX * (1 - zoomAmount),\n );\n const newUpper = computeLerp(\n model.window,\n dataType,\n (1 - relativeX) * zoomAmount + relativeX,\n );\n if (newLower !== newUpper) {\n this.setModel({\n ...model,\n window: [newLower, newUpper] as DataTypeInterval,\n });\n }\n },\n );\n }\n /**\n * Get fraction of distance in x along bounding rect for a MouseEvent.\n */\n getTargetFraction(event: MouseEvent) {\n const clientRect = this.element.getBoundingClientRect();\n return (event.clientX - clientRect.left) / clientRect.width;\n }\n updateValue(value: TransferFunctionParameters | undefined) {\n if (value === undefined) return;\n this.setModel(value);\n }\n convertPanelSpaceInputToAbsoluteValue(inputValue: number) {\n return computeLerp(\n this.transferFunction.trackable.value.window,\n this.dataType,\n inputValue,\n );\n }\n convertPanelSpaceColorToAbsoluteValue(color: vec3 | vec4) {\n if (color.length === 3) {\n // If color is vec3\n return vec3.fromValues(\n Math.round(color[0] * 255),\n Math.round(color[1] * 255),\n Math.round(color[2] * 255),\n );\n } else {\n // If color is vec4\n return vec4.fromValues(\n Math.round(color[0] * 255),\n Math.round(color[1] * 255),\n Math.round(color[2] * 255),\n Math.round(color[3] * 255),\n );\n }\n }\n addControlPoint(event: MouseEvent): TransferFunctionParameters | undefined {\n const color = this.transferFunction.trackable.value.defaultColor;\n const nearestIndex = this.findControlPointIfNearCursor(event);\n if (nearestIndex !== -1) {\n this.currentGrabbedControlPointIndex = nearestIndex;\n return undefined;\n }\n const position = this.getControlPointPosition(event);\n if (position === undefined) return undefined;\n const { normalizedX, normalizedY } = position;\n const outputColor = vec4.fromValues(\n color[0],\n color[1],\n color[2],\n normalizedY,\n );\n this.transferFunction.addPoint(\n new ControlPoint(\n this.convertPanelSpaceInputToAbsoluteValue(normalizedX),\n this.convertPanelSpaceColorToAbsoluteValue(outputColor) as vec4,\n ),\n );\n this.currentGrabbedControlPointIndex =\n this.findControlPointIfNearCursor(event);\n return {\n ...this.getModel(),\n sortedControlPoints:\n this.transferFunction.trackable.value.sortedControlPoints,\n };\n }\n moveControlPoint(event: MouseEvent): TransferFunctionParameters | undefined {\n if (this.currentGrabbedControlPointIndex !== -1) {\n const position = this.getControlPointPosition(event);\n if (position === undefined) return undefined;\n const { normalizedX, normalizedY } = position;\n const newColor =\n this.transferFunction.trackable.value.sortedControlPoints.controlPoints[\n this.currentGrabbedControlPointIndex\n ].outputColor;\n newColor[3] = Math.round(normalizedY * 255);\n this.currentGrabbedControlPointIndex = this.transferFunction.updatePoint(\n this.currentGrabbedControlPointIndex,\n new ControlPoint(\n this.convertPanelSpaceInputToAbsoluteValue(normalizedX),\n newColor,\n ),\n );\n return {\n ...this.getModel(),\n sortedControlPoints:\n this.transferFunction.trackable.value.sortedControlPoints,\n };\n }\n return undefined;\n }\n getControlPointPosition(event: MouseEvent): CanvasPosition | undefined {\n const clientRect = this.element.getBoundingClientRect();\n let normalizedX = (event.clientX - clientRect.left) / clientRect.width;\n let normalizedY = (clientRect.bottom - event.clientY) / clientRect.height;\n if (\n normalizedX < 0 ||\n normalizedX > 1 ||\n normalizedY < 0 ||\n normalizedY > 1\n )\n return undefined;\n\n // Near the borders of the transfer function, snap the control point to the border\n if (normalizedX < TRANSFER_FUNCTION_BORDER_WIDTH / 3) {\n normalizedX = 0.0;\n } else if (normalizedX > 1 - TRANSFER_FUNCTION_BORDER_WIDTH / 3) {\n normalizedX = 1.0;\n }\n if (normalizedY < TRANSFER_FUNCTION_BORDER_WIDTH) {\n normalizedY = 0.0;\n } else if (normalizedY > 1 - TRANSFER_FUNCTION_BORDER_WIDTH) {\n normalizedY = 1.0;\n }\n\n return { normalizedX, normalizedY };\n }\n /**\n * Find the nearest control point to the cursor or -1 if no control point is near the cursor.\n * If multiple control points are near the cursor in X, the control point with the smallest\n * distance in the Y direction is returned.\n */\n findControlPointIfNearCursor(event: MouseEvent) {\n const { transferFunction } = this;\n const { window } = transferFunction.trackable.value;\n const numControlPoints =\n transferFunction.sortedControlPoints.controlPoints.length;\n function convertControlPointInputToPanelSpace(controlPointIndex: number) {\n if (controlPointIndex < 0 || controlPointIndex >= numControlPoints) {\n return null;\n }\n return computeInvlerp(\n window,\n transferFunction.sortedControlPoints.controlPoints[controlPointIndex]\n .inputValue,\n );\n }\n function convertControlPointOpacityToPanelSpace(controlPointIndex: number) {\n if (controlPointIndex < 0 || controlPointIndex >= numControlPoints) {\n return null;\n }\n return (\n transferFunction.sortedControlPoints.controlPoints[controlPointIndex]\n .outputColor[3] / 255\n );\n }\n const position = this.getControlPointPosition(event);\n if (position === undefined) return -1;\n const mouseXPosition = position.normalizedX;\n const mouseYPosition = position.normalizedY;\n const nearestControlPointIndex =\n transferFunction.findNearestControlPointIndex(mouseXPosition, window);\n if (nearestControlPointIndex === -1) {\n return -1;\n }\n const nearestControlPointPanelPosition =\n convertControlPointInputToPanelSpace(nearestControlPointIndex)!;\n if (\n Math.abs(mouseXPosition - nearestControlPointPanelPosition) >\n CONTROL_POINT_X_GRAB_DISTANCE\n ) {\n return -1;\n }\n // If points are nearby in X space, use Y space to break ties\n const possibleMatches: [number, number][] = [\n [\n nearestControlPointIndex,\n Math.abs(\n convertControlPointOpacityToPanelSpace(nearestControlPointIndex)! -\n mouseYPosition,\n ),\n ],\n ];\n const nextPosition = convertControlPointInputToPanelSpace(\n nearestControlPointIndex + 1,\n );\n const nextDistance =\n nextPosition !== null\n ? Math.abs(nextPosition - mouseXPosition)\n : Infinity;\n if (nextDistance <= CONTROL_POINT_X_GRAB_DISTANCE) {\n possibleMatches.push([\n nearestControlPointIndex + 1,\n Math.abs(\n convertControlPointOpacityToPanelSpace(\n nearestControlPointIndex + 1,\n )! - mouseYPosition,\n ),\n ]);\n }\n\n const previousPosition = convertControlPointInputToPanelSpace(\n nearestControlPointIndex - 1,\n );\n const previousDistance =\n previousPosition !== null\n ? Math.abs(previousPosition - mouseXPosition)\n : Infinity;\n if (previousDistance <= CONTROL_POINT_X_GRAB_DISTANCE) {\n possibleMatches.push([\n nearestControlPointIndex - 1,\n Math.abs(\n convertControlPointOpacityToPanelSpace(\n nearestControlPointIndex - 1,\n )! - mouseYPosition,\n ),\n ]);\n }\n const bestMatch = possibleMatches.sort((a, b) => a[1] - b[1])[0][0];\n return bestMatch;\n }\n}\n\n/**\n * Widget for the transfer function. Creates the UI elements required for the transfer function.\n */\nclass TransferFunctionWidget extends Tab {\n private transferFunctionPanel = this.registerDisposer(\n new TransferFunctionPanel(this),\n );\n\n window = createWindowBoundInputs(this.dataType, this.trackable);\n\n get texture() {\n return this.histogramSpecifications.getFramebuffers(this.display.gl)[\n this.histogramIndex\n ].colorBuffers[0].texture;\n }\n constructor(\n visibility: WatchableVisibilityPriority,\n public display: DisplayContext,\n public dataType: DataType,\n public trackable: WatchableValueInterface,\n public histogramSpecifications: HistogramSpecifications,\n public histogramIndex: number,\n ) {\n super(visibility);\n this.registerDisposer(\n histogramSpecifications.visibility.add(this.visibility),\n );\n const { element } = this;\n element.classList.add(\"neuroglancer-transfer-function-widget\");\n element.appendChild(this.transferFunctionPanel.element);\n\n // Range bounds element\n element.appendChild(this.window.container);\n this.window.container.dispatchEvent(new Event(\"change\"));\n\n // Color picker element\n const colorPickerDiv = document.createElement(\"div\");\n colorPickerDiv.classList.add(\"neuroglancer-transfer-function-color-picker\");\n const colorPicker = this.registerDisposer(\n new ColorWidget(\n makeCachedDerivedWatchableValue(\n (x: TransferFunctionParameters) => x.defaultColor,\n [trackable],\n ),\n () => vec3.fromValues(1, 1, 1),\n ),\n );\n colorPicker.element.title = \"Transfer Function Color Picker\";\n colorPicker.element.id = \"neuroglancer-tf-color-widget\";\n colorPicker.element.addEventListener(\"change\", () => {\n trackable.value = {\n ...this.trackable.value,\n defaultColor: colorPicker.model.value,\n };\n });\n colorPicker.element.addEventListener(\"input\", () => {\n trackable.value = {\n ...this.trackable.value,\n defaultColor: colorPicker.model.value,\n };\n });\n colorPickerDiv.appendChild(colorPicker.element);\n\n element.appendChild(colorPickerDiv);\n this.updateControlPointsAndDraw();\n this.registerDisposer(\n this.trackable.changed.add(() => {\n this.updateControlPointsAndDraw();\n }),\n );\n }\n updateView() {\n for (let i = 0; i < 2; ++i) {\n updateInputBoundValue(\n this.window.inputs[i],\n this.trackable.value.window[i],\n );\n }\n this.transferFunctionPanel.scheduleRedraw();\n }\n updateControlPointsAndDraw() {\n this.transferFunctionPanel.update();\n this.updateView();\n }\n}\n\n/**\n * Create a shader function for the transfer function to grab the nearest lookup table value\n */\nexport function defineTransferFunctionShader(\n builder: ShaderBuilder,\n name: string,\n dataType: DataType,\n channel: number[],\n) {\n builder.addUniform(\"highp float\", `uTransferFunctionEnd_${name}`);\n builder.addTextureSampler(\n \"sampler2D\",\n `uTransferFunctionSampler_${name}`,\n `TransferFunction.${name}`,\n );\n const invlerpShaderCode = defineInvlerpShaderFunction(\n builder,\n name,\n dataType,\n true,\n ) as ShaderCodePart[];\n const shaderType = getShaderType(dataType);\n // Use ${name}_ to avoid name collisions with other shader functions in the case of FLOAT32 dtype\n let code = `\nvec4 ${name}_(float inputValue) {\n int index = clamp(int(round(inputValue * uTransferFunctionEnd_${name})), 0, int(uTransferFunctionEnd_${name}));\n return texelFetch(uTransferFunctionSampler_${name}, ivec2(index, 0), 0);\n}\nvec4 ${name}(${shaderType} inputValue) {\n float v = computeInvlerp(inputValue, uLerpParams_${name});\n defaultMaxProjectionIntensity = v;\n return v < 0.0 ? vec4(0.0, 0.0, 0.0, 0.0) : ${name}_(clamp(v, 0.0, 1.0));\n}\nvec4 ${name}() {\n return ${name}(getDataValue(${channel.join(\",\")}));\n}\n`;\n if (dataType !== DataType.UINT64 && dataType !== DataType.FLOAT32) {\n const scalarType = DATA_TYPE_SIGNED[dataType] ? \"int\" : \"uint\";\n code += `\nvec4 ${name}(${scalarType} inputValue) {\n return ${name}(${shaderType}(inputValue));\n}\n`;\n }\n return [\n invlerpShaderCode[0],\n invlerpShaderCode[1],\n invlerpShaderCode[2],\n code,\n ];\n}\n\n/**\n * Create a lookup table and bind that lookup table to a shader via uniforms\n */\nexport function enableTransferFunctionShader(\n shader: ShaderProgram,\n name: string,\n dataType: DataType,\n sortedControlPoints: SortedControlPoints,\n lookupTableSize: number = defaultTransferFunctionSizes[dataType],\n) {\n const { gl } = shader;\n const texture = shader.transferFunctionTextures.get(\n `TransferFunction.${name}`,\n );\n // Create a lookup table texture if it does not exist\n if (texture === undefined) {\n shader.transferFunctionTextures.set(\n `TransferFunction.${name}`,\n new ControlPointTexture(gl),\n );\n }\n const textureSize = shader.bindAndUpdateTransferFunctionTexture(\n `TransferFunction.${name}`,\n sortedControlPoints,\n dataType,\n lookupTableSize,\n );\n if (textureSize === undefined) {\n throw new Error(\"Failed to create transfer function texture\");\n }\n\n // Bind the length of the lookup table to the shader as a uniform\n gl.uniform1f(shader.uniform(`uTransferFunctionEnd_${name}`), textureSize - 1);\n\n // Use the lerp shader function to grab an index into the lookup table\n const interval = sortedControlPoints.range;\n enableLerpShaderFunction(shader, name, dataType, interval);\n}\n\n/**\n * Behaviour of the transfer function widget in the tool popup window\n */\nexport function activateTransferFunctionTool(\n activation: ToolActivation,\n control: TransferFunctionWidget,\n) {\n activation.bindInputEventMap(inputEventMap);\n control;\n}\n\n/**\n * Create a layer control factory for the transfer function widget\n */\nexport function transferFunctionLayerControl(\n getter: (layer: LayerType) => {\n watchableValue: WatchableValueInterface;\n defaultChannel: number[];\n channelCoordinateSpaceCombiner: CoordinateSpaceCombiner | undefined;\n histogramSpecifications: HistogramSpecifications;\n histogramIndex: number;\n dataType: DataType;\n },\n): LayerControlFactory {\n return {\n makeControl: (layer, context, options) => {\n const {\n watchableValue,\n channelCoordinateSpaceCombiner,\n defaultChannel,\n histogramSpecifications,\n histogramIndex,\n dataType,\n } = getter(layer);\n\n // Setup the ability to change the channel through the UI here\n // but only if the data has multiple channels\n if (\n channelCoordinateSpaceCombiner !== undefined &&\n defaultChannel.length !== 0\n ) {\n const position = context.registerDisposer(\n new Position(channelCoordinateSpaceCombiner.combined),\n );\n const positiionWidget = context.registerDisposer(\n new PositionWidget(position, channelCoordinateSpaceCombiner, {\n copyButton: false,\n }),\n );\n context.registerDisposer(\n position.changed.add(() => {\n const value = position.value;\n const newChannel = Array.from(value, (x) => Math.floor(x));\n const oldParams = watchableValue.value;\n if (!arraysEqual(oldParams.channel, newChannel)) {\n watchableValue.value = {\n ...watchableValue.value,\n channel: newChannel,\n };\n }\n }),\n );\n const updatePosition = () => {\n const value = position.value;\n const params = watchableValue.value;\n if (!arraysEqual(params.channel, value)) {\n value.set(params.channel);\n position.changed.dispatch();\n }\n };\n updatePosition();\n context.registerDisposer(watchableValue.changed.add(updatePosition));\n options.labelContainer.appendChild(positiionWidget.element);\n }\n const control = context.registerDisposer(\n new TransferFunctionWidget(\n options.visibility,\n options.display,\n dataType,\n watchableValue,\n histogramSpecifications,\n histogramIndex,\n ),\n );\n return { control, controlElement: control.element };\n },\n activateTool: (activation, control) => {\n activateTransferFunctionTool(activation, control);\n },\n };\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { CoordinateSpaceCombiner } from \"#src/coordinate_transform.js\";\nimport { TrackableBoolean } from \"#src/trackable_boolean.js\";\nimport type {\n TrackableValueInterface,\n WatchableValueInterface,\n} from \"#src/trackable_value.js\";\nimport {\n constantWatchableValue,\n makeCachedDerivedWatchableValue,\n makeCachedLazyDerivedWatchableValue,\n TrackableValue,\n} from \"#src/trackable_value.js\";\nimport { arraysEqual, arraysEqualWithPredicate } from \"#src/util/array.js\";\nimport {\n parseRGBColorSpecification,\n serializeColor,\n TrackableRGB,\n} from \"#src/util/color.js\";\nimport { DataType } from \"#src/util/data_type.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { kZeroVec4, vec3, vec4 } from \"#src/util/geom.js\";\nimport {\n parseArray,\n parseFixedLengthArray,\n verifyFiniteFloat,\n verifyInt,\n verifyObject,\n verifyOptionalObjectProperty,\n verifyString,\n} from \"#src/util/json.js\";\nimport type { DataTypeInterval } from \"#src/util/lerp.js\";\nimport {\n computeLerp,\n convertDataTypeInterval,\n dataTypeIntervalToJson,\n defaultDataTypeRange,\n normalizeDataTypeInterval,\n parseDataTypeInterval,\n parseDataTypeValue,\n parseUnknownDataTypeInterval,\n validateDataTypeInterval,\n} from \"#src/util/lerp.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport type { Trackable } from \"#src/util/trackable.js\";\nimport type { Uint64 } from \"#src/util/uint64.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { HistogramChannelSpecification } from \"#src/webgl/empirical_cdf.js\";\nimport { HistogramSpecifications } from \"#src/webgl/empirical_cdf.js\";\nimport {\n defineInvlerpShaderFunction,\n enableLerpShaderFunction,\n} from \"#src/webgl/lerp.js\";\nimport type { ShaderBuilder, ShaderProgram } from \"#src/webgl/shader.js\";\nimport type { TransferFunctionParameters } from \"#src/widget/transfer_function.js\";\nimport {\n defineTransferFunctionShader,\n enableTransferFunctionShader,\n SortedControlPoints,\n ControlPoint,\n} from \"#src/widget/transfer_function.js\";\n\nexport interface ShaderSliderControl {\n type: \"slider\";\n valueType: \"int\" | \"uint\" | \"float\";\n min: number;\n max: number;\n step: number;\n default: number;\n}\n\nexport interface ShaderColorControl {\n type: \"color\";\n valueType: \"vec3\";\n defaultString: string;\n default: vec3;\n}\n\nexport interface ShaderImageInvlerpControl {\n type: \"imageInvlerp\";\n dataType: DataType;\n clamp: boolean;\n default: ImageInvlerpParameters;\n}\n\nexport type PropertiesSpecification = Map;\n\nexport interface ShaderPropertyInvlerpControl {\n type: \"propertyInvlerp\";\n clamp: boolean;\n properties: PropertiesSpecification;\n default: PropertyInvlerpParameters;\n}\n\nexport interface ShaderCheckboxControl {\n type: \"checkbox\";\n valueType: \"bool\";\n default: boolean;\n}\n\nexport interface ShaderTransferFunctionControl {\n type: \"transferFunction\";\n dataType: DataType;\n default: TransferFunctionParameters;\n}\n\nexport type ShaderUiControl =\n | ShaderSliderControl\n | ShaderColorControl\n | ShaderImageInvlerpControl\n | ShaderPropertyInvlerpControl\n | ShaderCheckboxControl\n | ShaderTransferFunctionControl;\n\nexport interface ShaderControlParseError {\n line: number;\n message: string;\n}\n\nexport interface ShaderControlsParseResult {\n // Original source code entered by user.\n source: string;\n // Source code with comments stripped and UI controls replaced by appropriate text.\n code: string;\n controls: Map;\n errors: ShaderControlParseError[];\n}\n\nexport interface ShaderControlsBuilderState {\n key: string;\n parseResult: ShaderControlsParseResult;\n builderValues: ShaderBuilderValues;\n referencedProperties: string[];\n}\n\n// Strips comments from GLSL code. Also handles string literals since they are used in ui control\n// directives.\nexport function stripComments(code: string) {\n // https://stackoverflow.com/a/241506\n const commentPattern =\n /\\/\\/.*?$|\\/\\*(?:.|\\n)*?\\*\\/|'(?:\\\\.|[^\\\\'])*'|\"(?:\\\\.|[^\\\\\"])*\"/gm;\n return code.replace(commentPattern, (m) => {\n if (m.startsWith(\"/\")) {\n return m.replace(/[^\\s]/g, \" \");\n }\n return m;\n });\n}\n\ntype DirectiveParameters = Map;\n\n// Returns the length of the prefix that may be a valid directive parameter.\nfunction matchDirectiveParameterValue(input: string): number {\n const valueTokenPattern =\n /^(?:-?(?:0|[1-9]\\d*)(?:\\.\\d+)?(?:[eE][+-]?\\d+)?|\"(?:\\\\.|[^\\\\\"])*\"|true|false|:|\\s+|,|\\[|\\]|\\{|\\})/;\n let depth = 0;\n const initialInput = input;\n outerLoop: while (input.length) {\n const m = input.match(valueTokenPattern);\n if (m === null) break;\n const token = m[0];\n switch (token.charAt(0)) {\n case \"[\":\n case \"{\":\n ++depth;\n break;\n case \"]\":\n case \"}\":\n if (--depth < 0) return -1;\n break;\n case \",\":\n if (depth === 0) break outerLoop;\n break;\n default:\n if (depth === 0) {\n input = input.substring(token.length);\n break outerLoop;\n }\n break;\n }\n input = input.substring(token.length);\n }\n if (depth !== 0) return -1;\n return initialInput.length - input.length;\n}\n\nexport function parseDirectiveParameters(input: string | undefined): {\n parameters: DirectiveParameters;\n errors: string[];\n} {\n const errors: string[] = [];\n const parameters = new Map();\n if (input === undefined) {\n return { errors, parameters };\n }\n const startPattern = /^([_a-z][_a-zA-Z0-9]*)[ \\t]*=/;\n while (true) {\n input = input.trim();\n if (input.length === 0) break;\n const m = input.match(startPattern);\n if (m === null) {\n errors.push(\n \"Invalid #uicontrol parameter syntax, expected: =, ...\",\n );\n break;\n }\n const name = m[1];\n input = input.substring(m[0].length);\n const valueLength = matchDirectiveParameterValue(input);\n if (valueLength <= 0) {\n errors.push(\n \"Invalid #uicontrol parameter syntax, expected: =, ...\",\n );\n break;\n }\n let value;\n try {\n value = JSON.parse(input.substring(0, valueLength));\n } catch {\n errors.push(`Invalid #uicontrol parameter value for ${name}: ${value}`);\n break;\n }\n if (parameters.has(name)) {\n errors.push(`Duplicate #uicontrol parameter: ${name}`);\n } else {\n parameters.set(name, value);\n }\n input = input.substring(valueLength);\n input = input.trim();\n if (input.length > 0 && !input.startsWith(\",\")) {\n errors.push(\n \"Invalid #uicontrol parameter syntax, expected: =, ...\",\n );\n }\n input = input.substring(1);\n }\n return { parameters, errors };\n}\n\ntype DirectiveParseResult =\n | {\n control: ShaderUiControl;\n errors: undefined;\n }\n | { errors: string[] };\n\nfunction parseSliderDirective(\n valueType: string,\n parameters: DirectiveParameters,\n): DirectiveParseResult {\n let min: number | undefined;\n let max: number | undefined;\n let step: number | undefined;\n let defaultValue: number | undefined;\n const errors = [];\n if (valueType !== \"float\" && valueType !== \"uint\" && valueType !== \"int\") {\n errors.push(\"type must be float, int, or uint\");\n }\n for (const [key, value] of parameters) {\n const getValue = (): number | undefined => {\n if (typeof value !== \"number\") {\n errors.push(`Expected ${key} argument to be a number`);\n return undefined;\n }\n if (valueType === \"int\" || valueType === \"uint\") {\n if (!Number.isInteger(value)) {\n errors.push(`Expected ${key} argument to be an integer`);\n }\n if (valueType === \"uint\" && value < 0) {\n errors.push(`Expected ${key} argument to be an unsigned integer`);\n }\n }\n return value;\n };\n if (key === \"min\") {\n min = getValue();\n } else if (key === \"max\") {\n max = getValue();\n } else if (key === \"default\") {\n defaultValue = getValue();\n } else if (key === \"step\") {\n step = getValue();\n } else {\n errors.push(`Invalid parameter: ${key}`);\n }\n }\n if (min === undefined) {\n errors.push(\"min must be specified\");\n }\n if (max === undefined) {\n errors.push(\"max must be specified\");\n }\n if (min !== undefined && max !== undefined) {\n if (min > max) {\n errors.push(\"min must be less than max\");\n }\n if (step === undefined) {\n if (valueType === \"float\") {\n step = (max - min) / 100;\n } else {\n step = 1;\n }\n }\n if (defaultValue !== undefined) {\n if (defaultValue < min || defaultValue > max) {\n errors.push(\"default must be within valid range\");\n }\n } else {\n if (valueType === \"float\") {\n defaultValue = (min + max) / 2;\n } else {\n defaultValue = min;\n }\n }\n }\n if (errors.length > 0) {\n return { errors };\n }\n return {\n control: {\n type: \"slider\",\n valueType,\n min,\n max,\n step,\n default: defaultValue,\n } as ShaderSliderControl,\n errors: undefined,\n };\n}\n\nfunction parseCheckboxDirective(\n valueType: string,\n parameters: DirectiveParameters,\n): DirectiveParseResult {\n let defaultValue = false;\n const errors = [];\n if (valueType !== \"bool\") {\n errors.push(\"type must be bool\");\n }\n for (const [key, value] of parameters) {\n if (key === \"default\") {\n if (typeof value !== \"boolean\") {\n errors.push(`Expected ${key} argument to be a boolean`);\n continue;\n }\n defaultValue = value;\n } else {\n errors.push(`Invalid parameter: ${key}`);\n }\n }\n if (errors.length > 0) {\n return { errors };\n }\n return {\n control: {\n type: \"checkbox\",\n valueType,\n default: defaultValue,\n } as ShaderCheckboxControl,\n errors: undefined,\n };\n}\n\nfunction parseColorDirective(\n valueType: string,\n parameters: DirectiveParameters,\n): DirectiveParseResult {\n let defaultColor = \"white\";\n const errors = [];\n if (valueType !== \"vec3\") {\n errors.push(\"type must be vec3\");\n }\n for (const [key, value] of parameters) {\n if (key === \"default\") {\n if (typeof value !== \"string\") {\n errors.push(\"Expected default argument to be a string\");\n } else {\n defaultColor = value;\n }\n } else {\n errors.push(`Invalid parameter: ${key}`);\n }\n }\n if (errors.length > 0) {\n return { errors };\n }\n return {\n control: {\n type: \"color\",\n valueType,\n defaultString: defaultColor,\n default: parseRGBColorSpecification(defaultColor),\n } as ShaderColorControl,\n errors: undefined,\n };\n}\n\nfunction parseInvlerpChannel(value: unknown, rank: number) {\n if (typeof value === \"number\") {\n value = [value];\n }\n const channel = new Array(rank);\n parseFixedLengthArray(channel, value, (x) => {\n if (!Number.isInteger(x) || x < 0) {\n throw new Error(\n `Expected non-negative integer, but received: ${JSON.stringify(x)}`,\n );\n }\n return x;\n });\n return channel;\n}\n\nfunction parseInvlerpDirective(\n valueType: string,\n parameters: DirectiveParameters,\n dataContext: ShaderDataContext,\n): DirectiveParseResult {\n const { imageData, properties } = dataContext;\n if (imageData !== undefined) {\n return parseImageInvlerpDirective(valueType, parameters, imageData);\n }\n if (properties !== undefined) {\n return parsePropertyInvlerpDirective(valueType, parameters, properties);\n }\n const errors = [];\n errors.push(\"invlerp control not supported\");\n return { errors };\n}\n\nfunction parseImageInvlerpDirective(\n valueType: string,\n parameters: DirectiveParameters,\n imageData: ImageDataSpecification,\n) {\n const errors = [];\n if (valueType !== \"invlerp\") {\n errors.push(\"type must be invlerp\");\n }\n let channel = new Array(imageData.channelRank).fill(0);\n const { dataType } = imageData;\n let clamp = true;\n let range = defaultDataTypeRange[dataType];\n let window: DataTypeInterval | undefined;\n for (const [key, value] of parameters) {\n try {\n switch (key) {\n case \"range\": {\n range = parseDataTypeInterval(value, dataType);\n break;\n }\n case \"window\": {\n window = validateDataTypeInterval(\n parseDataTypeInterval(value, dataType),\n );\n break;\n }\n case \"clamp\": {\n if (typeof value !== \"boolean\") {\n errors.push(`Invalid clamp value: ${JSON.stringify(value)}`);\n } else {\n clamp = value;\n }\n break;\n }\n case \"channel\": {\n channel = parseInvlerpChannel(value, channel.length);\n break;\n }\n default:\n errors.push(`Invalid parameter: ${key}`);\n break;\n }\n } catch (e) {\n errors.push(`Invalid ${key} value: ${e.message}`);\n }\n }\n if (errors.length > 0) {\n return { errors };\n }\n return {\n control: {\n type: \"imageInvlerp\",\n dataType,\n clamp,\n default: {\n range,\n window: window ?? normalizeDataTypeInterval(range),\n channel,\n },\n } as ShaderImageInvlerpControl,\n errors: undefined,\n };\n}\n\nfunction parsePropertyInvlerpDirective(\n valueType: string,\n parameters: DirectiveParameters,\n properties: Map,\n) {\n const errors = [];\n if (valueType !== \"invlerp\") {\n errors.push(\"type must be invlerp\");\n }\n let clamp = true;\n let range: any;\n let window: any;\n let property: string | undefined;\n for (const [key, value] of parameters) {\n try {\n switch (key) {\n case \"range\": {\n range = parseUnknownDataTypeInterval(value);\n break;\n }\n case \"window\": {\n window = parseUnknownDataTypeInterval(value);\n break;\n }\n case \"clamp\": {\n if (typeof value !== \"boolean\") {\n errors.push(`Invalid clamp value: ${JSON.stringify(value)}`);\n } else {\n clamp = value;\n }\n break;\n }\n case \"property\": {\n const s = verifyString(value);\n if (!properties.has(s)) {\n throw new Error(\n `Property not defined: ${JSON.stringify(property)}`,\n );\n }\n property = s;\n break;\n }\n default:\n errors.push(`Invalid parameter: ${key}`);\n break;\n }\n } catch (e) {\n errors.push(`Invalid ${key} value: ${e.message}`);\n }\n }\n if (errors.length > 0) {\n return { errors };\n }\n if (property === undefined) {\n for (const p of properties.keys()) {\n property = p;\n break;\n }\n }\n const dataType = properties.get(property!)!;\n if (range !== undefined) {\n range = convertDataTypeInterval(range, dataType);\n }\n if (window !== undefined) {\n window = convertDataTypeInterval(window, dataType);\n }\n return {\n control: {\n type: \"propertyInvlerp\",\n clamp,\n properties,\n default: { range, window, property, dataType },\n } as ShaderPropertyInvlerpControl,\n errors: undefined,\n };\n}\n\nfunction parseTransferFunctionDirective(\n valueType: string,\n parameters: DirectiveParameters,\n dataContext: ShaderDataContext,\n): DirectiveParseResult {\n const imageData = dataContext.imageData;\n const dataType = imageData?.dataType;\n const channelRank = imageData?.channelRank;\n const errors = [];\n let channel = new Array(channelRank).fill(0);\n let defaultColor = vec3.fromValues(1.0, 1.0, 1.0);\n let window: DataTypeInterval | undefined;\n let sortedControlPoints = new SortedControlPoints(\n [],\n dataType !== undefined ? dataType : DataType.FLOAT32,\n );\n let specifedPoints = false;\n if (valueType !== \"transferFunction\") {\n errors.push(\"type must be transferFunction\");\n }\n if (dataType === undefined) {\n errors.push(\"image data must be provided to use a transfer function\");\n }\n for (const [key, value] of parameters) {\n try {\n switch (key) {\n case \"channel\": {\n channel = parseInvlerpChannel(value, channel.length);\n break;\n }\n case \"defaultColor\": {\n defaultColor = parseRGBColorSpecification(value);\n break;\n }\n case \"window\": {\n if (dataType !== undefined) {\n window = validateDataTypeInterval(\n parseDataTypeInterval(value, dataType),\n );\n }\n break;\n }\n case \"controlPoints\": {\n specifedPoints = true;\n if (dataType !== undefined) {\n sortedControlPoints = parseTransferFunctionControlPoints(\n value,\n dataType,\n );\n }\n break;\n }\n default:\n errors.push(`Invalid parameter: ${key}`);\n break;\n }\n } catch (e) {\n errors.push(`Invalid ${key} value: ${e.message}`);\n }\n }\n\n if (window === undefined) {\n window = sortedControlPoints.range;\n }\n // Set a simple black to white transfer function if no control points are specified.\n if (\n sortedControlPoints.length === 0 &&\n !specifedPoints &&\n dataType !== undefined\n ) {\n const startPoint = computeLerp(window, dataType, 0.4) as number;\n const endPoint = computeLerp(window, dataType, 0.7) as number;\n sortedControlPoints.addPoint(new ControlPoint(startPoint, kZeroVec4));\n sortedControlPoints.addPoint(\n new ControlPoint(endPoint, vec4.fromValues(255, 255, 255, 255)),\n );\n }\n if (errors.length > 0) {\n return { errors };\n }\n return {\n control: {\n type: \"transferFunction\",\n dataType,\n default: {\n sortedControlPoints,\n channel,\n defaultColor,\n window,\n },\n } as ShaderTransferFunctionControl,\n errors: undefined,\n };\n}\n\nexport interface ImageDataSpecification {\n dataType: DataType;\n channelRank: number;\n}\n\nexport interface ShaderDataContext {\n imageData?: ImageDataSpecification;\n properties?: Map;\n}\n\nconst controlParsers = new Map<\n string,\n (\n valueType: string,\n parameters: DirectiveParameters,\n context: ShaderDataContext,\n ) => DirectiveParseResult\n>([\n [\"slider\", parseSliderDirective],\n [\"color\", parseColorDirective],\n [\"invlerp\", parseInvlerpDirective],\n [\"checkbox\", parseCheckboxDirective],\n [\"transferFunction\", parseTransferFunctionDirective],\n]);\n\nexport function parseShaderUiControls(\n code: string,\n dataContext: ShaderDataContext = {},\n): ShaderControlsParseResult {\n code = stripComments(code);\n // Matches any #uicontrols directive. Syntax errors in the directive are handled later.\n const directivePattern = /^[ \\t]*#[ \\t]*uicontrol[ \\t]+(.*)$/gm;\n const innerPattern =\n /^([_a-zA-Z][_a-zA-Z0-9]*)[ \\t]+([a-z][a-zA-Z0-9_]*)(?:[ \\t]+([a-z]+))?[ \\t]*(?:\\([ \\t]*(.*)\\)[ \\t]*)?/;\n const errors: { line: number; message: string }[] = [];\n const controls = new Map();\n const newCode = code.replace(\n directivePattern,\n (_match, innerPart: string, offset: number) => {\n const m = innerPart.match(innerPattern);\n const getLineNumber = () => {\n return Math.max(0, code.substring(0, offset).split(\"\\n\").length - 1);\n };\n if (m === null) {\n errors.push({\n line: getLineNumber(),\n message:\n \"Invalid #uicontrol syntax, expected: #uicontrol (=, ...)\",\n });\n return \"\";\n }\n const typeName = m[1];\n const variableName = m[2];\n const controlName = m[3] ?? typeName;\n const parameterText = m[4];\n const { parameters, errors: innerErrors } =\n parseDirectiveParameters(parameterText);\n for (const error of innerErrors) {\n errors.push({ line: getLineNumber(), message: error });\n }\n if (controls.has(variableName)) {\n errors.push({\n line: getLineNumber(),\n message: `Duplicate definition for control ${variableName}`,\n });\n }\n if (innerErrors.length > 0) {\n return \"\";\n }\n const parser = controlParsers.get(controlName);\n if (parser === undefined) {\n errors.push({\n line: getLineNumber(),\n message: `Invalid control type ${controlName}`,\n });\n return \"\";\n }\n const result = parser(typeName, parameters, dataContext);\n if (result.errors !== undefined) {\n for (const error of result.errors) {\n errors.push({ line: getLineNumber(), message: error });\n }\n return \"\";\n }\n controls.set(variableName, result.control);\n return \"\";\n },\n );\n return { source: code, code: newCode, errors, controls };\n}\n\nexport type Controls = Map;\n\nfunction uniformName(controlName: string) {\n return `u_shaderControl_${controlName}`;\n}\n\nexport function addControlsToBuilder(\n builderState: ShaderControlsBuilderState,\n builder: ShaderBuilder,\n) {\n const { builderValues } = builderState;\n for (const [name, control] of builderState.parseResult.controls) {\n const uName = uniformName(name);\n const builderValue = builderValues[name];\n switch (control.type) {\n case \"imageInvlerp\": {\n const code = [\n defineInvlerpShaderFunction(\n builder,\n uName,\n control.dataType,\n control.clamp,\n ),\n `\nfloat ${uName}() {\n return ${uName}(getDataValue(${builderValue.channel.join(\",\")}));\n}\n`,\n ];\n builder.addFragmentCode(code);\n builder.addFragmentCode(`#define ${name} ${uName}\\n`);\n break;\n }\n case \"propertyInvlerp\": {\n const property = builderValue.property;\n const dataType = control.properties.get(property)!;\n const code = [\n defineInvlerpShaderFunction(builder, uName, dataType, control.clamp),\n `\nfloat ${uName}() {\n return ${uName}(prop_${property}());\n}\n`,\n ];\n builder.addVertexCode(code);\n builder.addVertexCode(`#define ${name} ${uName}\\n`);\n break;\n }\n case \"checkbox\": {\n const code = `#define ${name} ${builderValue.value}\\n`;\n builder.addFragmentCode(code);\n builder.addVertexCode(code);\n break;\n }\n case \"transferFunction\": {\n builder.addFragmentCode(`#define ${name} ${uName}\\n`);\n builder.addFragmentCode(\n defineTransferFunctionShader(\n builder,\n uName,\n control.dataType,\n builderValue.channel,\n ),\n );\n break;\n }\n default: {\n builder.addUniform(`highp ${control.valueType}`, uName);\n builder.addVertexCode(`#define ${name} ${uName}\\n`);\n builder.addFragmentCode(`#define ${name} ${uName}\\n`);\n break;\n }\n }\n }\n}\n\nfunction objectFromEntries(entries: Iterable<[string, any]>) {\n const obj: any = {};\n for (const [key, value] of entries) {\n obj[key] = value;\n }\n return obj;\n}\n\nfunction replaceMap(_key: string, value: unknown) {\n if (value instanceof Map) {\n return Array.from(value.entries());\n }\n return value;\n}\n\nfunction encodeControls(controls: Controls | undefined) {\n if (controls === undefined) return undefined;\n return JSON.stringify(objectFromEntries(controls), replaceMap);\n}\n\nexport class WatchableShaderUiControls\n implements WatchableValueInterface\n{\n changed = new NullarySignal();\n controls: Controls | undefined = undefined;\n get value() {\n return this.controls;\n }\n set value(newControls: Controls | undefined) {\n if (encodeControls(newControls) === encodeControls(this.controls)) {\n return;\n }\n this.controls = newControls;\n this.changed.dispatch();\n }\n}\n\nexport interface InvlerpParameters {\n range: DataTypeInterval;\n window: DataTypeInterval;\n}\n\nexport interface ImageInvlerpParameters extends InvlerpParameters {\n channel: number[];\n}\n\nexport interface PropertyInvlerpParameters {\n range: DataTypeInterval | undefined;\n window: DataTypeInterval | undefined;\n property: string;\n dataType: DataType;\n}\n\nfunction parseImageInvlerpParameters(\n obj: unknown,\n dataType: DataType,\n defaultValue: ImageInvlerpParameters,\n): ImageInvlerpParameters {\n if (obj === undefined) return defaultValue;\n verifyObject(obj);\n return {\n range: verifyOptionalObjectProperty(\n obj,\n \"range\",\n (x) => parseDataTypeInterval(x, dataType),\n defaultValue.range,\n ),\n window: verifyOptionalObjectProperty(\n obj,\n \"window\",\n (x) => validateDataTypeInterval(parseDataTypeInterval(x, dataType)),\n defaultValue.window,\n ),\n channel: verifyOptionalObjectProperty(\n obj,\n \"channel\",\n (x) => parseInvlerpChannel(x, defaultValue.channel.length),\n defaultValue.channel,\n ),\n };\n}\n\nclass TrackableImageInvlerpParameters extends TrackableValue {\n constructor(\n public dataType: DataType,\n public defaultValue: ImageInvlerpParameters,\n ) {\n super(defaultValue, (obj) =>\n parseImageInvlerpParameters(obj, dataType, defaultValue),\n );\n }\n\n toJSON() {\n const {\n value: { range, window, channel },\n dataType,\n defaultValue,\n } = this;\n const rangeJson = dataTypeIntervalToJson(\n range,\n dataType,\n defaultValue.range,\n );\n const windowJson = dataTypeIntervalToJson(\n window,\n dataType,\n defaultValue.window,\n );\n const channelJson = arraysEqual(defaultValue.channel, channel)\n ? undefined\n : channel;\n if (\n rangeJson === undefined &&\n windowJson === undefined &&\n channelJson === undefined\n ) {\n return undefined;\n }\n return { range: rangeJson, window: windowJson, channel: channelJson };\n }\n}\n\nfunction parsePropertyInvlerpParameters(\n obj: unknown,\n properties: PropertiesSpecification,\n defaultValue: PropertyInvlerpParameters,\n): PropertyInvlerpParameters {\n if (obj === undefined) return defaultValue;\n verifyObject(obj);\n const property = verifyOptionalObjectProperty(\n obj,\n \"property\",\n (property) => {\n property = verifyString(property);\n if (!properties.has(property)) {\n throw new Error(`Invalid value: ${JSON.stringify(property)}`);\n }\n return property;\n },\n defaultValue.property,\n );\n const dataType = properties.get(property)!;\n return {\n property,\n dataType,\n range: verifyOptionalObjectProperty(\n obj,\n \"range\",\n (x) => parseDataTypeInterval(x, dataType),\n defaultValue.range,\n ),\n window: verifyOptionalObjectProperty(\n obj,\n \"window\",\n (x) => validateDataTypeInterval(parseDataTypeInterval(x, dataType)),\n defaultValue.window,\n ),\n };\n}\n\nclass TrackablePropertyInvlerpParameters extends TrackableValue {\n constructor(\n public properties: PropertiesSpecification,\n public defaultValue: PropertyInvlerpParameters,\n ) {\n super(defaultValue, (obj) =>\n parsePropertyInvlerpParameters(obj, properties, defaultValue),\n );\n }\n\n toJSON() {\n const {\n value: { range, window, property, dataType },\n defaultValue,\n } = this;\n const defaultRange = defaultDataTypeRange[dataType];\n const rangeJson = dataTypeIntervalToJson(\n range ?? defaultRange,\n dataType,\n defaultValue.range ?? defaultRange,\n );\n const windowJson = dataTypeIntervalToJson(\n window ?? defaultRange,\n dataType,\n defaultValue.window ?? defaultRange,\n );\n const propertyJson =\n property === defaultValue.property ? undefined : property;\n if (\n rangeJson === undefined &&\n windowJson === undefined &&\n propertyJson === undefined\n ) {\n return undefined;\n }\n return { range: rangeJson, window: windowJson, property: propertyJson };\n }\n}\n\nfunction parseTransferFunctionControlPoints(\n controlPointsDefinition: unknown,\n dataType: DataType,\n) {\n const parsedPoints = parseArray(controlPointsDefinition, (x) => {\n // Validate input length and types\n const allowedInput =\n dataType === DataType.UINT64\n ? typeof x[0] === \"string\" || typeof x[0] === \"number\"\n : typeof x[0] === \"number\";\n if (\n x.length !== 3 ||\n !allowedInput ||\n typeof x[1] !== \"string\" ||\n typeof x[2] !== \"number\"\n ) {\n throw new Error(\n `Expected array of length 3 (x, \"#RRGGBB\", A), but received: ${JSON.stringify(\n x,\n )}`,\n );\n }\n const inputValue = parseDataTypeValue(dataType, x[0]);\n\n if (x[1].length !== 7 || x[1][0] !== \"#\") {\n throw new Error(\n `Expected #RRGGBB, but received: ${JSON.stringify(x[1])}`,\n );\n }\n if (x[2] < 0 || x[2] > 1) {\n throw new Error(\n `Expected opacity in range [0, 1], but received: ${JSON.stringify(\n x[2],\n )}`,\n );\n }\n const color = parseRGBColorSpecification(x[1]);\n function floatToUint8(float: number) {\n return Math.min(255, Math.max(Math.round(float * 255), 0));\n }\n return new ControlPoint(\n inputValue,\n vec4.fromValues(\n floatToUint8(color[0]),\n floatToUint8(color[1]),\n floatToUint8(color[2]),\n floatToUint8(x[2]),\n ),\n );\n });\n return new SortedControlPoints(parsedPoints, dataType);\n}\n\nexport function parseTransferFunctionParameters(\n obj: unknown,\n dataType: DataType,\n defaultValue: TransferFunctionParameters,\n): TransferFunctionParameters {\n if (obj === undefined) return defaultValue;\n verifyObject(obj);\n const sortedControlPoints = verifyOptionalObjectProperty(\n obj,\n \"controlPoints\",\n (x) => parseTransferFunctionControlPoints(x, dataType),\n defaultValue.sortedControlPoints,\n );\n const window = verifyOptionalObjectProperty(\n obj,\n \"window\",\n (x) => parseDataTypeInterval(x, dataType),\n defaultValue.window,\n );\n return {\n sortedControlPoints,\n channel: verifyOptionalObjectProperty(\n obj,\n \"channel\",\n (x) => parseInvlerpChannel(x, defaultValue.channel.length),\n defaultValue.channel,\n ),\n defaultColor: verifyOptionalObjectProperty(\n obj,\n \"defaultColor\",\n (x) => parseRGBColorSpecification(x),\n defaultValue.defaultColor,\n ),\n window,\n };\n}\n\nfunction copyTransferFunctionParameters(\n defaultValue: TransferFunctionParameters,\n) {\n return {\n ...defaultValue,\n sortedControlPoints: defaultValue.sortedControlPoints.copy(),\n };\n}\n\nexport class TrackableTransferFunctionParameters extends TrackableValue {\n constructor(\n public dataType: DataType,\n public defaultValue: TransferFunctionParameters,\n ) {\n // Create a copy of the default value to enable detecting changes\n // to the control points in the trackable value.\n const defaultValueCopy = copyTransferFunctionParameters(defaultValue);\n super(defaultValueCopy, (obj) =>\n parseTransferFunctionParameters(obj, dataType, defaultValueCopy),\n );\n }\n\n controlPointsToJson(controlPoints: ControlPoint[], dataType: DataType) {\n function inputToJson(inputValue: number | Uint64) {\n if (dataType === DataType.UINT64) {\n return (inputValue as Uint64).toJSON();\n }\n return inputValue;\n }\n\n return controlPoints.map((x) => [\n inputToJson(x.inputValue),\n serializeColor(\n vec3.fromValues(\n x.outputColor[0] / 255,\n x.outputColor[1] / 255,\n x.outputColor[2] / 255,\n ),\n ),\n x.outputColor[3] / 255,\n ]);\n }\n\n toJSON() {\n const {\n value: { channel, sortedControlPoints, defaultColor, window },\n dataType,\n defaultValue,\n } = this;\n const windowJson = dataTypeIntervalToJson(\n window,\n dataType,\n defaultValue.window,\n );\n const channelJson = arraysEqual(defaultValue.channel, channel)\n ? undefined\n : channel;\n const colorJson = arraysEqual(defaultValue.defaultColor, defaultColor)\n ? undefined\n : serializeColor(defaultColor);\n const controlPointsJson = arraysEqualWithPredicate(\n defaultValue.sortedControlPoints.controlPoints,\n sortedControlPoints.controlPoints,\n (a, b) =>\n arraysEqual(a.outputColor, b.outputColor) &&\n a.inputValue === b.inputValue,\n )\n ? undefined\n : this.controlPointsToJson(sortedControlPoints.controlPoints, dataType);\n if (\n channelJson === undefined &&\n colorJson === undefined &&\n controlPointsJson === undefined &&\n windowJson === undefined\n ) {\n return undefined;\n }\n return {\n channel: channelJson,\n defaultColor: colorJson,\n controlPoints: controlPointsJson,\n window: windowJson,\n };\n }\n}\n\nfunction getControlTrackable(control: ShaderUiControl): {\n trackable: TrackableValueInterface;\n getBuilderValue: (value: any) => any;\n} {\n switch (control.type) {\n case \"slider\":\n return {\n trackable: new TrackableValue(control.default, (x) => {\n let v: number;\n if (control.valueType === \"float\") {\n v = verifyFiniteFloat(x);\n } else {\n v = verifyInt(x);\n }\n if (v < control.min || v > control.max) {\n throw new Error(\n `${JSON.stringify(x)} is outside valid range [${control.min}, ${\n control.max\n }]`,\n );\n }\n return v;\n }),\n getBuilderValue: () => null,\n };\n case \"color\":\n return {\n trackable: new TrackableRGB(control.default),\n getBuilderValue: () => null,\n };\n case \"imageInvlerp\":\n return {\n trackable: new TrackableImageInvlerpParameters(\n control.dataType,\n control.default,\n ),\n getBuilderValue: (value: ImageInvlerpParameters) => ({\n channel: value.channel,\n dataType: control.dataType,\n }),\n };\n case \"propertyInvlerp\":\n return {\n trackable: new TrackablePropertyInvlerpParameters(\n control.properties,\n control.default,\n ),\n getBuilderValue: (value: PropertyInvlerpParameters) => ({\n property: value.property,\n dataType: value.dataType,\n }),\n };\n case \"checkbox\":\n return {\n trackable: new TrackableBoolean(control.default),\n getBuilderValue: (value) => ({ value }),\n };\n case \"transferFunction\":\n return {\n trackable: new TrackableTransferFunctionParameters(\n control.dataType,\n control.default,\n ),\n getBuilderValue: (value: TransferFunctionParameters) => ({\n channel: value.channel,\n dataType: control.dataType,\n }),\n };\n }\n}\n\nexport interface SingleShaderControlState {\n control: ShaderUiControl;\n trackable: TrackableValueInterface;\n getBuilderValue: (value: any) => any;\n}\n\nexport type ShaderControlMap = Map;\n\nexport type ShaderBuilderValues = {\n [key: string]: any;\n};\n\nfunction encodeBuilderStateKey(\n builderValues: ShaderBuilderValues,\n parseResult: ShaderControlsParseResult,\n) {\n return JSON.stringify(builderValues) + \"\\0\" + parseResult.source;\n}\n\nexport function getFallbackBuilderState(\n parseResult: ShaderControlsParseResult,\n): ShaderControlsBuilderState {\n const builderValues: ShaderBuilderValues = {};\n const referencedProperties = [];\n for (const [key, control] of parseResult.controls) {\n const { trackable, getBuilderValue } = getControlTrackable(control);\n const builderValue = getBuilderValue(trackable.value);\n builderValues[key] = builderValue;\n if (control.type === \"propertyInvlerp\") {\n referencedProperties.push(builderValue.property);\n }\n }\n return {\n builderValues,\n parseResult,\n key: encodeBuilderStateKey(builderValues, parseResult),\n referencedProperties,\n };\n}\n\nexport class ShaderControlState\n extends RefCounted\n implements Trackable, WatchableValueInterface\n{\n changed = new NullarySignal();\n controls = new WatchableShaderUiControls();\n parseErrors: WatchableValueInterface;\n processedFragmentMain: WatchableValueInterface;\n parseResult: WatchableValueInterface;\n builderState: WatchableValueInterface;\n histogramSpecifications: HistogramSpecifications;\n\n private fragmentMainGeneration = -1;\n private dataContextGeneration = -1;\n private parseErrors_: ShaderControlParseError[] = [];\n private processedFragmentMain_ = \"\";\n private parseResult_: ShaderControlsParseResult;\n private controlsGeneration = -1;\n private parseResultChanged = new NullarySignal();\n\n constructor(\n public fragmentMain: WatchableValueInterface,\n public dataContext: WatchableValueInterface = constantWatchableValue(\n {},\n ),\n public channelCoordinateSpaceCombiner?: CoordinateSpaceCombiner | undefined,\n ) {\n super();\n this.registerDisposer(\n fragmentMain.changed.add(() => this.handleFragmentMainChanged()),\n );\n this.registerDisposer(\n this.controls.changed.add(() => this.handleControlsChanged()),\n );\n this.registerDisposer(\n this.dataContext.changed.add(() => this.handleFragmentMainChanged()),\n );\n this.handleFragmentMainChanged();\n const self = this;\n this.parseErrors = {\n changed: this.parseResultChanged,\n get value() {\n self.handleFragmentMainChanged();\n return self.parseErrors_;\n },\n };\n this.processedFragmentMain = {\n changed: this.parseResultChanged,\n get value() {\n self.handleFragmentMainChanged();\n return self.processedFragmentMain_;\n },\n };\n this.parseResult = {\n changed: this.parseResultChanged,\n get value() {\n return self.parseResult_;\n },\n };\n this.builderState = makeCachedDerivedWatchableValue(\n (parseResult: ShaderControlsParseResult, state: ShaderControlMap) => {\n const builderValues: ShaderBuilderValues = {};\n const referencedProperties = [];\n for (const [key, { control, trackable, getBuilderValue }] of state) {\n const builderValue = getBuilderValue(trackable.value);\n builderValues[key] = builderValue;\n if (control.type === \"propertyInvlerp\") {\n referencedProperties.push(builderValue.property);\n }\n }\n return {\n key: encodeBuilderStateKey(builderValues, parseResult),\n parseResult,\n builderValues,\n referencedProperties,\n };\n },\n [this.parseResult, this],\n (a, b) => a.key === b.key,\n );\n const histogramChannels = makeCachedDerivedWatchableValue(\n (state) => {\n const channels: HistogramChannelSpecification[] = [];\n for (const { control, trackable } of state.values()) {\n if (\n control.type !== \"imageInvlerp\" &&\n control.type !== \"transferFunction\"\n )\n continue;\n channels.push({ channel: trackable.value.channel });\n }\n return channels;\n },\n [this],\n (a, b) =>\n arraysEqualWithPredicate(a, b, (ca, cb) =>\n arraysEqual(ca.channel, cb.channel),\n ),\n );\n const histogramProperties = makeCachedDerivedWatchableValue(\n (state) => {\n const properties: string[] = [];\n for (const { control, trackable } of state.values()) {\n if (control.type !== \"propertyInvlerp\") continue;\n properties.push(trackable.value.property);\n }\n return properties;\n },\n [this],\n arraysEqual,\n );\n const histogramBounds = makeCachedLazyDerivedWatchableValue((state) => {\n const bounds: DataTypeInterval[] = [];\n for (const { control, trackable } of state.values()) {\n if (\n control.type === \"imageInvlerp\" ||\n control.type === \"transferFunction\"\n ) {\n bounds.push(trackable.value.window);\n } else if (control.type === \"propertyInvlerp\") {\n const { dataType, range, window } =\n trackable.value as PropertyInvlerpParameters;\n bounds.push(window ?? range ?? defaultDataTypeRange[dataType]);\n }\n }\n return bounds;\n }, this);\n this.histogramSpecifications = this.registerDisposer(\n new HistogramSpecifications(\n histogramChannels,\n histogramProperties,\n histogramBounds,\n ),\n );\n }\n\n private handleFragmentMainChanged() {\n const generation = this.fragmentMain.changed.count;\n const dataContextGeneration = this.dataContext.changed.count;\n if (\n generation === this.fragmentMainGeneration &&\n dataContextGeneration === this.dataContextGeneration\n ) {\n return;\n }\n this.fragmentMainGeneration = generation;\n this.dataContextGeneration = dataContextGeneration;\n const dataContext = this.dataContext.value;\n if (dataContext === null) {\n this.parseResult_ = {\n source: \"\",\n code: \"\",\n controls: new Map(),\n errors: [{ line: 0, message: \"Loading\" }],\n };\n this.parseErrors_ = [];\n this.processedFragmentMain_ = \"\";\n this.controls.value = undefined;\n } else {\n const result = (this.parseResult_ = parseShaderUiControls(\n this.fragmentMain.value,\n dataContext,\n ));\n this.parseErrors_ = result.errors;\n this.processedFragmentMain_ = result.code;\n if (result.errors.length === 0) {\n this.controls.value = result.controls;\n }\n }\n this.parseResultChanged.dispatch();\n }\n\n private handleControlsChanged() {\n const generation = this.controls.changed.count;\n if (generation === this.controlsGeneration) {\n return;\n }\n this.controlsGeneration = generation;\n const controls = this.controls.value;\n if (controls === undefined) {\n return;\n }\n let changed = false;\n const { state_, unparsedJson } = this;\n // Remove values in `state` not in `controls`.\n for (const [name, controlState] of state_) {\n const control = controls.get(name);\n if (control === undefined) {\n controlState.trackable.changed.remove(this.changed.dispatch);\n state_.delete(name);\n changed = true;\n }\n }\n for (const [name, control] of controls) {\n let controlState = state_.get(name);\n if (\n controlState !== undefined &&\n JSON.stringify(controlState.control) !== JSON.stringify(control)\n ) {\n controlState.trackable.changed.remove(this.changed.dispatch);\n controlState = undefined;\n }\n if (controlState === undefined) {\n const { trackable, getBuilderValue } = getControlTrackable(control);\n controlState = { control, trackable, getBuilderValue };\n controlState.trackable.changed.add(this.changed.dispatch);\n state_.set(name, controlState);\n changed = true;\n }\n if (\n unparsedJson !== undefined &&\n Object.prototype.hasOwnProperty.call(unparsedJson, name)\n ) {\n changed = true;\n try {\n controlState.trackable.restoreState(unparsedJson[name]);\n } catch {\n // Ignore error\n }\n }\n }\n if (unparsedJson !== undefined) {\n changed = true;\n }\n this.unparsedJson = undefined;\n if (changed) {\n this.changed.dispatch();\n }\n }\n\n private state_: ShaderControlMap = new Map();\n\n get state() {\n if (this.controls.changed.count !== this.controlsGeneration) {\n this.handleControlsChanged();\n }\n return this.state_;\n }\n\n get value() {\n return this.state;\n }\n\n private unparsedJson: any = undefined;\n\n restoreState(value: any) {\n if (value === undefined) return;\n const { state } = this;\n verifyObject(value);\n const controls = this.controls.value;\n if (controls === undefined) {\n this.unparsedJson = value;\n this.changed.dispatch();\n return;\n }\n for (const [key, controlState] of state) {\n const { trackable } = controlState;\n trackable.reset();\n if (Object.prototype.hasOwnProperty.call(value, key)) {\n try {\n trackable.restoreState(value[key]);\n } catch {\n // Ignore error\n }\n }\n }\n this.unparsedJson = undefined;\n }\n\n reset() {\n for (const controlState of this.state.values()) {\n controlState.trackable.reset();\n }\n if (this.unparsedJson !== undefined) {\n this.unparsedJson = undefined;\n this.changed.dispatch();\n }\n }\n\n toJSON() {\n const { state } = this;\n const { unparsedJson } = this;\n if (unparsedJson !== undefined) return unparsedJson;\n const obj: any = {};\n let empty = true;\n for (const [key, value] of state) {\n const valueJson = value.trackable.toJSON();\n if (valueJson !== undefined) {\n obj[key] = valueJson;\n empty = false;\n }\n }\n if (empty) return undefined;\n return obj;\n }\n}\n\nfunction setControlInShader(\n gl: GL,\n shader: ShaderProgram,\n name: string,\n control: ShaderUiControl,\n value: any,\n) {\n const uName = uniformName(name);\n const uniform = shader.uniform(uName);\n switch (control.type) {\n case \"slider\":\n switch (control.valueType) {\n case \"int\":\n case \"uint\":\n gl.uniform1i(uniform, value);\n break;\n case \"float\":\n gl.uniform1f(uniform, value);\n }\n break;\n case \"color\":\n gl.uniform3fv(uniform, value);\n break;\n case \"imageInvlerp\":\n enableLerpShaderFunction(shader, uName, control.dataType, value.range);\n break;\n case \"propertyInvlerp\": {\n const { dataType } = value as PropertyInvlerpParameters;\n enableLerpShaderFunction(\n shader,\n uName,\n dataType,\n value.range ?? defaultDataTypeRange[dataType],\n );\n break;\n }\n case \"checkbox\":\n // Value is hard-coded in shader.\n break;\n case \"transferFunction\":\n enableTransferFunctionShader(\n shader,\n uName,\n control.dataType,\n value.sortedControlPoints,\n );\n }\n}\n\nexport function setControlsInShader(\n gl: GL,\n shader: ShaderProgram,\n shaderControlState: ShaderControlState,\n controls: Controls,\n) {\n const { state } = shaderControlState;\n if (shaderControlState.controls.value === controls) {\n // Case when shader doesn't have any errors.\n for (const [name, controlState] of state) {\n setControlInShader(\n gl,\n shader,\n name,\n controlState.control,\n controlState.trackable.value,\n );\n }\n } else {\n // Case when shader does have errors and we are using the fallback shader, which may have a\n // different/incompatible set of controls.\n for (const [name, control] of controls) {\n const controlState = state.get(name);\n const value =\n controlState !== undefined &&\n JSON.stringify(controlState.control) === JSON.stringify(control)\n ? controlState.trackable.value\n : control.default;\n setControlInShader(gl, shader, name, control, value);\n }\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { MultiscaleAnnotationSource } from \"#src/annotation/frontend_source.js\";\nimport type {\n AnnotationPropertySpec,\n AnnotationSource,\n} from \"#src/annotation/index.js\";\nimport { propertyTypeDataType } from \"#src/annotation/index.js\";\nimport type { LayerDataSource } from \"#src/layer/layer_data_source.js\";\nimport type {\n ChunkTransformParameters,\n RenderLayerTransformOrError,\n} from \"#src/render_coordinate_transform.js\";\nimport { getChunkTransformParameters } from \"#src/render_coordinate_transform.js\";\nimport { RenderLayerRole } from \"#src/renderlayer.js\";\nimport type { SegmentationDisplayState } from \"#src/segmentation_display_state/frontend.js\";\nimport { TrackableBoolean } from \"#src/trackable_boolean.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport {\n makeCachedLazyDerivedWatchableValue,\n registerNested,\n WatchableValue,\n} from \"#src/trackable_value.js\";\nimport { TrackableRGB } from \"#src/util/color.js\";\nimport type { DataType } from \"#src/util/data_type.js\";\nimport type { Owned } from \"#src/util/disposable.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type { ValueOrError } from \"#src/util/error.js\";\nimport { makeValueOrError, valueOrThrow } from \"#src/util/error.js\";\nimport { vec3 } from \"#src/util/geom.js\";\nimport { WatchableMap } from \"#src/util/watchable_map.js\";\nimport {\n makeTrackableFragmentMain,\n makeWatchableShaderError,\n} from \"#src/webgl/dynamic_shader.js\";\nimport {\n getFallbackBuilderState,\n parseShaderUiControls,\n ShaderControlState,\n} from \"#src/webgl/shader_ui_controls.js\";\n\nexport class AnnotationHoverState extends WatchableValue<\n | {\n id: string;\n partIndex: number;\n annotationLayerState: AnnotationLayerState;\n }\n | undefined\n> {}\n\n// null means loading\n// undefined means no attached layer\nexport type OptionalSegmentationDisplayState =\n | SegmentationDisplayState\n | null\n | undefined;\n\nexport interface AnnotationRelationshipState {\n segmentationState: WatchableValueInterface;\n showMatches: TrackableBoolean;\n}\n\nexport class WatchableAnnotationRelationshipStates extends WatchableMap<\n string,\n AnnotationRelationshipState\n> {\n constructor() {\n super((context, { showMatches, segmentationState }) => {\n context.registerDisposer(showMatches.changed.add(this.changed.dispatch));\n context.registerDisposer(\n segmentationState.changed.add(this.changed.dispatch),\n );\n context.registerDisposer(\n registerNested((nestedContext, segmentationState) => {\n if (segmentationState == null) return;\n const { segmentationGroupState } = segmentationState;\n nestedContext.registerDisposer(\n segmentationGroupState.changed.add(this.changed.dispatch),\n );\n nestedContext.registerDisposer(\n registerNested((groupContext, groupState) => {\n const { visibleSegments } = groupState;\n let wasEmpty = visibleSegments.size === 0;\n groupContext.registerDisposer(\n visibleSegments.changed.add(() => {\n const isEmpty = visibleSegments.size === 0;\n if (isEmpty !== wasEmpty) {\n wasEmpty = isEmpty;\n this.changed.dispatch();\n }\n }),\n );\n }, segmentationGroupState),\n );\n }, segmentationState),\n );\n });\n }\n\n get(name: string): AnnotationRelationshipState {\n let value = super.get(name);\n if (value === undefined) {\n value = {\n segmentationState: new WatchableValue(undefined),\n showMatches: new TrackableBoolean(false),\n };\n super.set(name, value);\n }\n return value;\n }\n}\n\nconst DEFAULT_FRAGMENT_MAIN = `\nvoid main() {\n setColor(defaultColor());\n}\n`;\n\nexport class AnnotationDisplayState extends RefCounted {\n annotationProperties = new WatchableValue<\n readonly Readonly[] | undefined\n >(undefined);\n shader = makeTrackableFragmentMain(DEFAULT_FRAGMENT_MAIN);\n shaderControls = new ShaderControlState(\n this.shader,\n makeCachedLazyDerivedWatchableValue((annotationProperties) => {\n const properties = new Map();\n if (annotationProperties === undefined) {\n return null;\n }\n for (const property of annotationProperties) {\n const dataType = propertyTypeDataType[property.type];\n if (dataType === undefined) continue;\n properties.set(property.identifier, dataType);\n }\n return { properties };\n }, this.annotationProperties),\n );\n fallbackShaderControls = new WatchableValue(\n getFallbackBuilderState(parseShaderUiControls(DEFAULT_FRAGMENT_MAIN)),\n );\n shaderError = makeWatchableShaderError();\n color = new TrackableRGB(vec3.fromValues(1, 1, 0));\n relationshipStates = this.registerDisposer(\n new WatchableAnnotationRelationshipStates(),\n );\n ignoreNullSegmentFilter = new TrackableBoolean(true);\n swapVisibleSegmentsOnMove = new TrackableBoolean(true);\n disablePicking = new WatchableValue(false);\n displayUnfiltered = makeCachedLazyDerivedWatchableValue(\n (map, ignoreNullSegmentFilter) => {\n for (const state of map.values()) {\n if (state.showMatches.value) {\n if (!ignoreNullSegmentFilter) return false;\n const segmentationState = state.segmentationState.value;\n if (segmentationState != null) {\n if (\n segmentationState.segmentationGroupState.value.visibleSegments\n .size > 0\n ) {\n return false;\n }\n }\n }\n }\n return true;\n },\n this.relationshipStates,\n this.ignoreNullSegmentFilter,\n );\n hoverState = new AnnotationHoverState(undefined);\n}\n\nexport class AnnotationLayerState extends RefCounted {\n transform: WatchableValueInterface;\n localPosition: WatchableValueInterface;\n source: Owned;\n role: RenderLayerRole;\n dataSource: LayerDataSource;\n subsourceId: string;\n subsourceIndex: number;\n displayState: AnnotationDisplayState;\n subsubsourceId?: string;\n\n readonly chunkTransform: WatchableValueInterface<\n ValueOrError\n >;\n\n constructor(options: {\n transform: WatchableValueInterface;\n localPosition: WatchableValueInterface;\n source: Owned;\n displayState: AnnotationDisplayState;\n dataSource: LayerDataSource;\n subsourceId: string;\n subsourceIndex: number;\n subsubsourceId?: string;\n role?: RenderLayerRole;\n }) {\n super();\n const {\n transform,\n localPosition,\n source,\n role = RenderLayerRole.ANNOTATION,\n } = options;\n this.transform = transform;\n this.localPosition = localPosition;\n this.source = this.registerDisposer(source);\n this.role = role;\n this.displayState = options.displayState;\n this.chunkTransform = this.registerDisposer(\n makeCachedLazyDerivedWatchableValue(\n (modelTransform) =>\n makeValueOrError(() =>\n getChunkTransformParameters(valueOrThrow(modelTransform)),\n ),\n this.transform,\n ),\n );\n this.dataSource = options.dataSource;\n this.subsourceId = options.subsourceId;\n this.subsourceIndex = options.subsourceIndex;\n this.subsubsourceId = options.subsubsourceId;\n }\n\n get sourceIndex() {\n const { dataSource } = this;\n return dataSource.layer.dataSources.indexOf(dataSource);\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n validateDisplayDimensionRenderInfoProperty,\n type DisplayDimensionRenderInfo,\n} from \"#src/navigation_state.js\";\nimport { ProjectionParameters } from \"#src/projection_parameters.js\";\nimport { getChunkPositionFromCombinedGlobalLocalPositions } from \"#src/render_coordinate_transform.js\";\nimport { ChunkLayout } from \"#src/sliceview/chunk_layout.js\";\nimport type {\n WatchableValueChangeInterface,\n WatchableValueInterface,\n} from \"#src/trackable_value.js\";\nimport { DATA_TYPE_BYTES, DataType } from \"#src/util/data_type.js\";\nimport type { Disposable } from \"#src/util/disposable.js\";\nimport {\n getFrustrumPlanes,\n getViewFrustrumDepthRange,\n isAABBIntersectingPlane,\n isAABBVisible,\n mat4,\n vec3,\n} from \"#src/util/geom.js\";\nimport * as matrix from \"#src/util/matrix.js\";\nimport * as vector from \"#src/util/vector.js\";\nimport { SharedObject } from \"#src/worker_rpc.js\";\n\nexport { DATA_TYPE_BYTES, DataType };\n\nconst DEBUG_VISIBLE_SOURCES = false;\nconst DEBUG_CHUNK_VISIBILITY = false;\n\nconst tempMat4 = mat4.create();\n\n/**\n * Average cross-sectional area contained within a chunk of the specified size and rotation.\n *\n * This is estimated by taking the total volume of the chunk and dividing it by the total length of\n * the chunk along the z axis.\n */\nexport function estimateSliceAreaPerChunk(\n chunkLayout: ChunkLayout,\n viewMatrix: mat4,\n) {\n // Compute the length of the projection of the chunk along the z axis in view space.\n //\n // Each chunk dimension `i` can independently affect the z projection by the dot product of column\n // `i` of `chunkLayout.transform` and row 2 of `viewMatrix`.\n let viewZProjection = 0;\n let chunkVolume = Math.abs(chunkLayout.detTransform);\n const { transform, size } = chunkLayout;\n for (let i = 0; i < 3; ++i) {\n let sum = 0;\n for (let j = 0; j < 3; ++j) {\n sum += viewMatrix[j * 4 + 2] * transform[4 * i + j];\n }\n const s = size[i];\n viewZProjection += Math.abs(sum) * s;\n chunkVolume *= s;\n }\n return chunkVolume / viewZProjection;\n}\n\nexport interface MultiscaleVolumetricDataRenderLayer {\n localPosition: WatchableValueInterface;\n renderScaleTarget: WatchableValueInterface;\n}\n\nexport interface TransformedSource<\n RLayer extends MultiscaleVolumetricDataRenderLayer = SliceViewRenderLayer,\n Source extends SliceViewChunkSource = SliceViewChunkSource,\n> {\n renderLayer: RLayer;\n\n source: Source;\n\n /**\n * Approximate voxel size in each of the display dimensions.\n */\n effectiveVoxelSize: vec3;\n\n chunkLayout: ChunkLayout;\n\n /**\n * Arrays of length `rank` specifying the clip bounds (in voxels) for dimensions not in\n * `chunkDisplayDimensionIndices` and not channel dimensions. The values for display/channel\n * dimensions are set to -/+infinity.\n */\n nonDisplayLowerClipBound: Float32Array;\n nonDisplayUpperClipBound: Float32Array;\n\n /**\n * Arrays of length `rank` specifying the clip bounds (in voxels) for all dimensions.\n */\n lowerClipBound: Float32Array;\n upperClipBound: Float32Array;\n\n // Lower clip bound (in voxels) in the \"display\" subspace of the chunk coordinate space.\n lowerClipDisplayBound: vec3;\n // Upper clip bound (in voxels) in the \"display\" subspace of the chunk coordinate space.\n upperClipDisplayBound: vec3;\n\n // Lower bound (in chunks) within the \"display\" subspace of the chunk coordinate space.\n lowerChunkDisplayBound: vec3;\n // Upper bound (in chunks) within the \"display\" subspace of the chunk coordinate space.\n upperChunkDisplayBound: vec3;\n\n /**\n * Dimensions of the chunk corresponding to the 3 display dimensions of the slice view.\n */\n chunkDisplayDimensionIndices: number[];\n\n /**\n * Rank of \"layer\" space and the \"chunk clip\" space, which is >= rank of chunk space.\n */\n layerRank: number;\n\n /**\n * Transform from dimensions of layer space to dimensions of chunk space.\n *\n * Matrix has dimensions `(globalRank + localRank + 1) * layerRank`.\n *\n * Input space is `[global dimensions, local dimensions]`. Output space is the \"chunk clip\"\n * coordinate space, in units of voxels.\n *\n */\n combinedGlobalLocalToChunkTransform: Float32Array;\n\n /**\n * Transform from non-display dimensions of layer space to non-display dimensions of chunk space.\n *\n * Same as `combinedGlobalLocalToChunkTransform`, except that rows corresponding to \"display\"\n * chunk dimensions are all 0.\n *\n * Matrix has dimensions `(globalRank + localRank + 1) * layerRank`.\n *\n * Input space is `[global dimensions, local dimensions]`. Output space is the \"chunk clip\"\n * coordinate space, in units of voxels.\n */\n fixedLayerToChunkTransform: Float32Array;\n\n /**\n * When `computeVisibleChunks` invokes the `addChunk` callback, this is set to the position of the\n * chunk.\n */\n curPositionInChunks: Float32Array;\n\n fixedPositionWithinChunk: Uint32Array;\n}\n\nexport interface SliceViewRenderLayer {\n /**\n * Current position of non-global layer dimensions.\n */\n localPosition: WatchableValueInterface;\n renderScaleTarget: WatchableValueInterface;\n\n filterVisibleSources(\n sliceView: SliceViewBase,\n sources: readonly TransformedSource[],\n ): Iterable;\n}\n\nfunction updateFixedCurPositionInChunks<\n RLayer extends MultiscaleVolumetricDataRenderLayer,\n>(\n tsource: TransformedSource,\n globalPosition: Float32Array,\n localPosition: Float32Array,\n): boolean {\n const { curPositionInChunks, fixedPositionWithinChunk } = tsource;\n const { nonDisplayLowerClipBound, nonDisplayUpperClipBound } = tsource;\n const { rank, chunkDataSize } = tsource.source.spec;\n if (\n !getChunkPositionFromCombinedGlobalLocalPositions(\n curPositionInChunks,\n globalPosition,\n localPosition,\n tsource.layerRank,\n tsource.fixedLayerToChunkTransform,\n )\n ) {\n return false;\n }\n for (let chunkDim = 0; chunkDim < rank; ++chunkDim) {\n const x = curPositionInChunks[chunkDim];\n if (\n x < nonDisplayLowerClipBound[chunkDim] ||\n x >= nonDisplayUpperClipBound[chunkDim]\n ) {\n if (DEBUG_VISIBLE_SOURCES) {\n console.log(\n \"excluding source\",\n tsource,\n `because of chunkDim=${chunkDim}, sum=${x}`,\n nonDisplayLowerClipBound,\n nonDisplayUpperClipBound,\n tsource.fixedLayerToChunkTransform,\n );\n }\n return false;\n }\n const chunkSize = chunkDataSize[chunkDim];\n const chunk = (curPositionInChunks[chunkDim] = Math.floor(x / chunkSize));\n fixedPositionWithinChunk[chunkDim] = x - chunk * chunkSize;\n }\n return true;\n}\n\nfunction pickBestAlternativeSource<\n RLayer extends MultiscaleVolumetricDataRenderLayer,\n Source extends SliceViewChunkSource,\n Transformed extends TransformedSource,\n>(viewMatrix: mat4, alternatives: Transformed[]) {\n const numAlternatives = alternatives.length;\n let bestAlternativeIndex = 0;\n if (DEBUG_VISIBLE_SOURCES) {\n console.log(alternatives);\n }\n if (numAlternatives > 1) {\n let bestSliceArea = 0;\n for (\n let alternativeIndex = 0;\n alternativeIndex < numAlternatives;\n ++alternativeIndex\n ) {\n const alternative = alternatives[alternativeIndex];\n const { chunkLayout } = alternative;\n const sliceArea = estimateSliceAreaPerChunk(chunkLayout, viewMatrix);\n if (DEBUG_VISIBLE_SOURCES) {\n console.log(\n `chunksize = ${chunkLayout.size}, sliceArea = ${sliceArea}`,\n );\n }\n if (sliceArea > bestSliceArea) {\n bestSliceArea = sliceArea;\n bestAlternativeIndex = alternativeIndex;\n }\n }\n }\n return bestAlternativeIndex;\n}\n\nexport interface VisibleLayerSources<\n RLayer extends MultiscaleVolumetricDataRenderLayer,\n Source extends SliceViewChunkSource,\n Transformed extends TransformedSource,\n> {\n allSources: Transformed[][];\n visibleSources: Transformed[];\n displayDimensionRenderInfo: DisplayDimensionRenderInfo;\n}\n\nconst tempChunkLayout = new ChunkLayout(vec3.create(), mat4.create(), 0);\n\nexport class SliceViewProjectionParameters extends ProjectionParameters {\n /**\n * Normal vector of cross section in (non-isotropic) global voxel coordinates.\n */\n viewportNormalInGlobalCoordinates = vec3.create();\n\n /**\n * Normal vector of cross section in isotropic global canonical voxel coordinates.\n */\n viewportNormalInCanonicalCoordinates = vec3.create();\n\n centerDataPosition = vec3.create();\n\n /**\n * Size in physical units of a single pixel.\n */\n pixelSize = 0;\n}\n\nfunction visibleSourcesInvalidated(\n oldValue: SliceViewProjectionParameters,\n newValue: SliceViewProjectionParameters,\n) {\n if (\n oldValue.displayDimensionRenderInfo !== newValue.displayDimensionRenderInfo\n ) {\n return true;\n }\n if (oldValue.pixelSize !== newValue.pixelSize) return true;\n const { viewMatrix: oldViewMatrix } = oldValue;\n const { viewMatrix: newViewMatrix } = newValue;\n for (let i = 0; i < 12; ++i) {\n if (oldViewMatrix[i] !== newViewMatrix[i]) return true;\n }\n return false;\n}\n\nexport class SliceViewBase<\n Source extends SliceViewChunkSource = SliceViewChunkSource,\n RLayer extends SliceViewRenderLayer = SliceViewRenderLayer,\n Transformed extends TransformedSource = TransformedSource<\n RLayer,\n Source\n >,\n> extends SharedObject {\n visibleLayers = new Map<\n RLayer,\n VisibleLayerSources\n >();\n visibleSourcesStale = true;\n\n constructor(\n public projectionParameters: WatchableValueChangeInterface,\n ) {\n super();\n this.registerDisposer(\n projectionParameters.changed.add((oldValue, newValue) => {\n if (visibleSourcesInvalidated(oldValue, newValue)) {\n this.invalidateVisibleSources();\n }\n this.invalidateVisibleChunks();\n }),\n );\n }\n\n invalidateVisibleSources() {\n this.visibleSourcesStale = true;\n }\n\n invalidateVisibleChunks() {}\n\n /**\n * Computes the list of sources to use for each visible layer, based on the\n * current pixelSize.\n */\n updateVisibleSources() {\n if (!this.visibleSourcesStale) {\n return;\n }\n this.visibleSourcesStale = false;\n const curDisplayDimensionRenderInfo =\n this.projectionParameters.value.displayDimensionRenderInfo;\n\n const { visibleLayers } = this;\n for (const [renderLayer, visibleLayerSources] of visibleLayers) {\n const { allSources, visibleSources } = visibleLayerSources;\n visibleSources.length = 0;\n if (\n allSources.length === 0 ||\n !validateDisplayDimensionRenderInfoProperty(\n visibleLayerSources,\n curDisplayDimensionRenderInfo,\n )\n ) {\n continue;\n }\n const preferredOrientationIndex = pickBestAlternativeSource(\n this.projectionParameters.value.viewMatrix,\n allSources.map((x) => x[0]),\n );\n\n const sources = allSources[preferredOrientationIndex];\n\n for (const source of renderLayer.filterVisibleSources(this, sources)) {\n visibleSources.push(source as Transformed);\n }\n // Reverse visibleSources list since we added sources from coarsest to finest resolution, but\n // we want them ordered from finest to coarsest.\n visibleSources.reverse();\n if (DEBUG_VISIBLE_SOURCES) {\n console.log(\"visible sources chosen\", visibleSources);\n }\n }\n }\n}\n\n/**\n * By default, choose a chunk size with at most 2^18 = 262144 voxels.\n */\nexport const DEFAULT_MAX_VOXELS_PER_CHUNK_LOG2 = 18;\n\n/**\n * Specifies common options for getNearIsotropicBlockSize and getTwoDimensionalBlockSize.\n */\nexport interface BaseChunkLayoutOptions {\n /**\n * Number of chunk dimensions.\n */\n rank: number;\n\n /**\n * This, together with upperVoxelBound, specifies the total volume dimensions, which serves as a\n * bound on the maximum chunk size. If not specified, defaults to a zero vector.\n */\n lowerVoxelBound?: Float32Array;\n\n /**\n * Upper voxel bound. If not specified, the total volume dimensions are not used to bound the\n * chunk size.\n */\n upperVoxelBound?: Float32Array;\n\n /**\n * Base 2 logarithm of the maximum number of voxels per chunk. Defaults to\n * DEFAULT_MAX_VOXELS_PER_CHUNK_LOG2.\n */\n maxVoxelsPerChunkLog2?: number;\n\n /**\n * Linear (not affine) transformation matrix with `rank` columns and `displayRank` rows in\n * column-major order. Specifies the transformation from chunk space to an isotropic \"camera view\n * space\". Note that only relative scales of input dimensions are relevant, any rotations applied\n * are irrelevant.\n */\n chunkToViewTransform: Float32Array;\n displayRank: number;\n\n minBlockSize?: Uint32Array;\n maxBlockSize?: Uint32Array;\n}\n\nexport type GetNearIsotropicBlockSizeOptions = BaseChunkLayoutOptions;\n\n/**\n * Determines a near-isotropic (in camera view space) block size. All dimensions will be\n * powers of 2, and will not exceed upperVoxelBound - lowerVoxelBound. The total number of voxels\n * will not exceed maxVoxelsPerChunkLog2.\n */\nexport function getNearIsotropicBlockSize(\n options: GetNearIsotropicBlockSizeOptions,\n): Uint32Array {\n let {\n rank,\n upperVoxelBound,\n maxVoxelsPerChunkLog2 = DEFAULT_MAX_VOXELS_PER_CHUNK_LOG2,\n chunkToViewTransform,\n displayRank,\n minBlockSize,\n maxBlockSize,\n } = options;\n\n const { lowerVoxelBound = new Uint32Array(rank) } = options;\n\n // Adjust voxelSize by effective scaling factor.\n const effectiveVoxelSize = new Float32Array(rank);\n for (let chunkDim = 0; chunkDim < rank; ++chunkDim) {\n let factor = 0;\n for (let displayDim = 0; displayDim < displayRank; ++displayDim) {\n const c = chunkToViewTransform[chunkDim * displayRank + displayDim];\n factor += c * c;\n }\n effectiveVoxelSize[chunkDim] = Math.sqrt(factor);\n }\n\n const chunkDataSize = new Uint32Array(rank);\n if (minBlockSize !== undefined) {\n chunkDataSize.set(minBlockSize);\n } else {\n chunkDataSize.fill(1);\n }\n const chunkDataSizeUpperBound = new Array(rank);\n for (let chunkDim = 0; chunkDim < rank; ++chunkDim) {\n let bound = Number.POSITIVE_INFINITY;\n if (effectiveVoxelSize[chunkDim] === 0) {\n bound = chunkDataSize[chunkDim];\n } else {\n if (upperVoxelBound !== undefined) {\n bound =\n 2 **\n Math.floor(\n Math.log2(upperVoxelBound[chunkDim] - lowerVoxelBound[chunkDim]),\n );\n }\n if (maxBlockSize !== undefined) {\n bound = Math.min(bound, maxBlockSize[chunkDim]);\n }\n }\n chunkDataSizeUpperBound[chunkDim] = bound;\n }\n\n // Determine the dimension in which chunkDataSize should be increased. This is the smallest\n // dimension (in nanometers) that is < maxChunkDataSize (in voxels).\n //\n // Returns -1 if there is no such dimension.\n function findNextDimension() {\n let minSize = Infinity;\n let minDimension = -1;\n for (let chunkDim = 0; chunkDim < rank; ++chunkDim) {\n if (chunkDataSize[chunkDim] >= chunkDataSizeUpperBound[chunkDim]) {\n continue;\n }\n const size = chunkDataSize[chunkDim] * effectiveVoxelSize[chunkDim];\n if (size < minSize) {\n minSize = size;\n minDimension = chunkDim;\n }\n }\n return minDimension;\n }\n\n maxVoxelsPerChunkLog2 -= Math.log2(vector.prod(chunkDataSize));\n for (let i = 0; i < maxVoxelsPerChunkLog2; ++i) {\n const nextDim = findNextDimension();\n if (nextDim === -1) {\n break;\n }\n chunkDataSize[nextDim] *= 2;\n }\n return chunkDataSize;\n}\n\n/**\n * Returns an array of [xy, yz, xz] 2-dimensional block sizes, where [x, y, z] refer to the view\n * dimensions.\n */\nexport function getTwoDimensionalBlockSizes(options: BaseChunkLayoutOptions) {\n const chunkDataSizes: Uint32Array[] = [];\n const { displayRank, chunkToViewTransform, rank } = options;\n if (displayRank > 3) {\n throw new Error(\"Unsupported view transform\");\n }\n if (displayRank < 3) {\n return [getNearIsotropicBlockSize(options)];\n }\n for (let i = 0; i < 3; ++i) {\n const excludedDim = (i + 2) % 3;\n const restrictedTransform = new Float32Array(chunkToViewTransform);\n for (let j = 0; j < rank; ++j) {\n restrictedTransform[j * displayRank + excludedDim] = 0;\n }\n chunkDataSizes[i] = getNearIsotropicBlockSize({\n ...options,\n chunkToViewTransform: restrictedTransform,\n });\n }\n return chunkDataSizes;\n}\n\nexport enum ChunkLayoutPreference {\n /**\n * Indicates that isotropic chunks are desired.\n */\n ISOTROPIC = 0,\n\n /**\n * Indicates that 2-D chunks are desired.\n */\n FLAT = 1,\n}\n\nexport interface SliceViewSourceOptions {\n /**\n * Transform from the multiscale source coordinate space to a \"view\" coordinate space that\n * reflects the relative scales. This is a *linear* (not affine) transformation matrix with\n * `rank` columns and `displayRank` rows in column-major order, where `rank` is the rank of the\n * multiscale source.\n */\n multiscaleToViewTransform: Float32Array;\n displayRank: number;\n modelChannelDimensionIndices: readonly number[];\n}\n\nexport function getCombinedTransform(\n rank: number,\n bToC: Float32Array,\n aToB: Float32Array | undefined,\n) {\n if (aToB === undefined) {\n return bToC;\n }\n return matrix.multiply(\n new Float32Array((rank + 1) * (rank + 1)),\n rank + 1,\n bToC,\n rank + 1,\n aToB,\n rank + 1,\n rank + 1,\n rank + 1,\n rank + 1,\n );\n}\n\n/**\n * Specifies parameters for getChunkDataSizes.\n */\nexport interface ChunkLayoutOptions {\n /**\n * Chunk sizes in voxels.\n */\n chunkDataSizes?: Uint32Array[];\n\n /**\n * Preferred chunk layout, which determines chunk sizes to use if chunkDataSizes is not\n * specified.\n */\n chunkLayoutPreference?: ChunkLayoutPreference;\n}\n\nexport function getChunkDataSizes(\n options: ChunkLayoutOptions & BaseChunkLayoutOptions,\n) {\n if (options.chunkDataSizes !== undefined) {\n return options.chunkDataSizes;\n }\n const { chunkLayoutPreference = ChunkLayoutPreference.ISOTROPIC } = options;\n switch (chunkLayoutPreference) {\n case ChunkLayoutPreference.ISOTROPIC:\n return [getNearIsotropicBlockSize(options)];\n case ChunkLayoutPreference.FLAT:\n return getTwoDimensionalBlockSizes(options);\n }\n}\n\n/**\n * Generic specification for SliceView chunks specifying a layout and voxel size.\n */\nexport interface SliceViewChunkSpecification<\n ChunkDataSize extends Uint32Array | Float32Array = Uint32Array | Float32Array,\n> {\n rank: number;\n\n /**\n * Size of chunk in voxels.\n */\n chunkDataSize: ChunkDataSize;\n\n /**\n * All valid chunks are in the range [lowerChunkBound, upperChunkBound).\n *\n * These are specified in units of chunks (not voxels).\n */\n lowerChunkBound: Float32Array;\n upperChunkBound: Float32Array;\n\n lowerVoxelBound: Float32Array;\n upperVoxelBound: Float32Array;\n}\n\nexport function makeSliceViewChunkSpecification<\n ChunkDataSize extends Uint32Array | Float32Array,\n>(\n options: SliceViewChunkSpecificationOptions,\n): SliceViewChunkSpecification {\n const { rank, chunkDataSize, upperVoxelBound } = options;\n const { lowerVoxelBound = new Float32Array(rank) } = options;\n const lowerChunkBound = new Float32Array(rank);\n const upperChunkBound = new Float32Array(rank);\n for (let i = 0; i < rank; ++i) {\n lowerChunkBound[i] = Math.floor(lowerVoxelBound[i] / chunkDataSize[i]);\n upperChunkBound[i] = Math.floor(\n (upperVoxelBound[i] - 1) / chunkDataSize[i] + 1,\n );\n }\n return {\n rank,\n chunkDataSize,\n lowerChunkBound,\n upperChunkBound,\n lowerVoxelBound,\n upperVoxelBound,\n };\n}\n\nexport function* filterVisibleSources(\n sliceView: SliceViewBase,\n renderLayer: SliceViewRenderLayer,\n sources: readonly TransformedSource[],\n): Iterable {\n // Increase pixel size by a small margin.\n const pixelSize = sliceView.projectionParameters.value.pixelSize * 1.1;\n // At the smallest scale, all alternative sources must have the same voxel size, which is\n // considered to be the base voxel size.\n const smallestVoxelSize = sources[0].effectiveVoxelSize;\n\n const renderScaleTarget = renderLayer.renderScaleTarget.value;\n\n /**\n * Determines whether we should continue to look for a finer-resolution source *after* one\n * with the specified voxelSize.\n */\n const canImproveOnVoxelSize = (voxelSize: vec3) => {\n const targetSize = pixelSize * renderScaleTarget;\n for (let i = 0; i < 3; ++i) {\n const size = voxelSize[i];\n // If size <= pixelSize, no need for improvement.\n // If size === smallestVoxelSize, also no need for improvement.\n if (size > targetSize && size > 1.01 * smallestVoxelSize[i]) {\n return true;\n }\n }\n return false;\n };\n\n const improvesOnPrevVoxelSize = (voxelSize: vec3, prevVoxelSize: vec3) => {\n const targetSize = pixelSize * renderScaleTarget;\n for (let i = 0; i < 3; ++i) {\n const size = voxelSize[i];\n const prevSize = prevVoxelSize[i];\n if (\n Math.abs(targetSize - size) < Math.abs(targetSize - prevSize) &&\n size < 1.01 * prevSize\n ) {\n return true;\n }\n }\n return false;\n };\n let scaleIndex = sources.length - 1;\n let prevVoxelSize: vec3 | undefined;\n while (true) {\n const transformedSource = sources[scaleIndex];\n if (\n prevVoxelSize !== undefined &&\n !improvesOnPrevVoxelSize(\n transformedSource.effectiveVoxelSize,\n prevVoxelSize,\n )\n ) {\n break;\n }\n yield transformedSource;\n\n if (\n scaleIndex === 0 ||\n !canImproveOnVoxelSize(transformedSource.effectiveVoxelSize)\n ) {\n break;\n }\n prevVoxelSize = transformedSource.effectiveVoxelSize;\n --scaleIndex;\n }\n}\n\n/**\n * Common parameters for SliceView Chunks.\n */\nexport interface SliceViewChunkSpecificationBaseOptions {\n rank: number;\n\n /**\n * If not specified, defaults to an all-zero vector. This determines lowerChunkBound. If this is\n * not a multiple of chunkDataSize, then voxels at lower positions may still be requested.\n */\n lowerVoxelBound?: Float32Array;\n\n /**\n * Exclusive upper bound in \"chunk\" coordinate space, in voxels. This determines upperChunkBound.\n */\n upperVoxelBound: Float32Array;\n}\n\nexport interface SliceViewChunkSpecificationOptions<\n ChunkDataSize extends Uint32Array | Float32Array = Uint32Array | Float32Array,\n> extends SliceViewChunkSpecificationBaseOptions {\n chunkDataSize: ChunkDataSize;\n}\n\nexport interface SliceViewChunkSource<\n Spec extends SliceViewChunkSpecification = SliceViewChunkSpecification,\n> extends Disposable {\n spec: Spec;\n}\n\nexport const SLICEVIEW_RPC_ID = \"SliceView\";\nexport const SLICEVIEW_RENDERLAYER_RPC_ID = \"sliceview/RenderLayer\";\nexport const SLICEVIEW_ADD_VISIBLE_LAYER_RPC_ID = \"SliceView.addVisibleLayer\";\nexport const SLICEVIEW_REMOVE_VISIBLE_LAYER_RPC_ID =\n \"SliceView.removeVisibleLayer\";\nexport const SLICEVIEW_REQUEST_CHUNK_RPC_ID = \"ChunkManager.requestChunk\";\n\nconst tempVisibleVolumetricChunkLower = new Float32Array(3);\nconst tempVisibleVolumetricChunkUpper = new Float32Array(3);\nconst tempVisibleVolumetricModelViewProjection = mat4.create();\nconst tempVisibleVolumetricClippingPlanes = new Float32Array(24);\n\nfunction forEachVolumetricChunkWithinFrustrum<\n RLayer extends MultiscaleVolumetricDataRenderLayer,\n>(\n clippingPlanes: Float32Array,\n transformedSource: TransformedSource,\n callback: (positionInChunks: vec3, clippingPlanes: Float32Array) => void,\n predicate: (\n xLower: number,\n yLower: number,\n zLower: number,\n xUpper: number,\n yUpper: number,\n zUpper: number,\n clippingPlanes: Float32Array,\n ) => boolean,\n) {\n const lower = tempVisibleVolumetricChunkLower;\n const upper = tempVisibleVolumetricChunkUpper;\n const { lowerChunkDisplayBound, upperChunkDisplayBound } = transformedSource;\n for (let i = 0; i < 3; ++i) {\n lower[i] = Math.max(lower[i], lowerChunkDisplayBound[i]);\n upper[i] = Math.min(upper[i], upperChunkDisplayBound[i]);\n }\n const { curPositionInChunks, chunkDisplayDimensionIndices } =\n transformedSource;\n\n function recurse() {\n if (\n !predicate(\n lower[0],\n lower[1],\n lower[2],\n upper[0],\n upper[1],\n upper[2],\n clippingPlanes,\n )\n ) {\n return;\n }\n\n let splitDim = 0;\n let splitSize = Math.max(0, upper[0] - lower[0]);\n let volume = splitSize;\n for (let i = 1; i < 3; ++i) {\n const size = Math.max(0, upper[i] - lower[i]);\n volume *= size;\n if (size > splitSize) {\n splitSize = size;\n splitDim = i;\n }\n }\n if (volume === 0) return;\n if (volume === 1) {\n curPositionInChunks[chunkDisplayDimensionIndices[0]] = lower[0];\n curPositionInChunks[chunkDisplayDimensionIndices[1]] = lower[1];\n curPositionInChunks[chunkDisplayDimensionIndices[2]] = lower[2];\n callback(lower as vec3, clippingPlanes);\n return;\n }\n const prevLower = lower[splitDim];\n const prevUpper = upper[splitDim];\n const splitPoint = Math.floor(0.5 * (prevLower + prevUpper));\n upper[splitDim] = splitPoint;\n recurse();\n upper[splitDim] = prevUpper;\n lower[splitDim] = splitPoint;\n recurse();\n lower[splitDim] = prevLower;\n }\n recurse();\n}\n\nexport function forEachVisibleVolumetricChunk<\n RLayer extends MultiscaleVolumetricDataRenderLayer,\n>(\n projectionParameters: ProjectionParameters,\n localPosition: Float32Array,\n transformedSource: TransformedSource,\n callback: (positionInChunks: vec3, clippingPlanes: Float32Array) => void,\n) {\n if (\n !updateFixedCurPositionInChunks(\n transformedSource,\n projectionParameters.globalPosition,\n localPosition,\n )\n ) {\n return;\n }\n const { size: chunkSize } = transformedSource.chunkLayout;\n const modelViewProjection = mat4.multiply(\n tempVisibleVolumetricModelViewProjection,\n projectionParameters.viewProjectionMat,\n transformedSource.chunkLayout.transform,\n );\n for (let i = 0; i < 3; ++i) {\n const s = chunkSize[i];\n for (let j = 0; j < 4; ++j) {\n modelViewProjection[4 * i + j] *= s;\n }\n }\n\n const clippingPlanes = tempVisibleVolumetricClippingPlanes;\n getFrustrumPlanes(clippingPlanes, modelViewProjection);\n const lower = tempVisibleVolumetricChunkLower;\n const upper = tempVisibleVolumetricChunkUpper;\n lower.fill(Number.NEGATIVE_INFINITY);\n upper.fill(Number.POSITIVE_INFINITY);\n forEachVolumetricChunkWithinFrustrum(\n clippingPlanes,\n transformedSource,\n callback,\n isAABBVisible,\n );\n}\n\nexport function forEachPlaneIntersectingVolumetricChunk<\n RLayer extends MultiscaleVolumetricDataRenderLayer,\n>(\n projectionParameters: ProjectionParameters,\n localPosition: Float32Array,\n transformedSource: TransformedSource,\n chunkLayout: ChunkLayout,\n callback: (positionInChunks: vec3) => void,\n) {\n if (\n !updateFixedCurPositionInChunks(\n transformedSource,\n projectionParameters.globalPosition,\n localPosition,\n )\n ) {\n return;\n }\n const { size: chunkSize } = chunkLayout;\n const modelViewProjection = mat4.multiply(\n tempVisibleVolumetricModelViewProjection,\n projectionParameters.viewProjectionMat,\n chunkLayout.transform,\n );\n for (let i = 0; i < 3; ++i) {\n const s = chunkSize[i];\n for (let j = 0; j < 4; ++j) {\n modelViewProjection[4 * i + j] *= s;\n }\n }\n\n const invModelViewProjection = tempMat4;\n mat4.invert(invModelViewProjection, modelViewProjection);\n const lower = tempVisibleVolumetricChunkLower;\n const upper = tempVisibleVolumetricChunkUpper;\n const epsilon = 1e-3;\n for (let i = 0; i < 3; ++i) {\n // Add small offset of `epsilon` voxels to bias towards the higher coordinate if very close to a\n // voxel boundary.\n const c = invModelViewProjection[12 + i] + epsilon / chunkSize[i];\n const xCoeff = Math.abs(invModelViewProjection[i]);\n const yCoeff = Math.abs(invModelViewProjection[4 + i]);\n lower[i] = Math.floor(c - xCoeff - yCoeff);\n upper[i] = Math.floor(c + xCoeff + yCoeff + 1);\n }\n\n const clippingPlanes = tempVisibleVolumetricClippingPlanes;\n for (let i = 0; i < 3; ++i) {\n const xCoeff = modelViewProjection[4 * i];\n const yCoeff = modelViewProjection[4 * i + 1];\n const zCoeff = modelViewProjection[4 * i + 2];\n clippingPlanes[i] = xCoeff;\n clippingPlanes[4 + i] = -xCoeff;\n clippingPlanes[8 + i] = +yCoeff;\n clippingPlanes[12 + i] = -yCoeff;\n clippingPlanes[16 + i] = +zCoeff;\n clippingPlanes[20 + i] = -zCoeff;\n }\n {\n const i = 3;\n const xCoeff = modelViewProjection[4 * i];\n const yCoeff = modelViewProjection[4 * i + 1];\n const zCoeff = modelViewProjection[4 * i + 2];\n clippingPlanes[i] = 1 + xCoeff;\n clippingPlanes[4 + i] = 1 - xCoeff;\n clippingPlanes[8 + i] = 1 + yCoeff;\n clippingPlanes[12 + i] = 1 - yCoeff;\n clippingPlanes[16 + i] = zCoeff;\n clippingPlanes[20 + i] = -zCoeff;\n }\n if (DEBUG_CHUNK_VISIBILITY) {\n console.log(\"clippingPlanes\", clippingPlanes);\n console.log(\"modelViewProjection\", modelViewProjection.join(\",\"));\n console.log(`lower=${lower.join(\",\")}, upper=${upper.join(\",\")}`);\n }\n forEachVolumetricChunkWithinFrustrum(\n clippingPlanes,\n transformedSource,\n callback,\n isAABBIntersectingPlane,\n );\n}\n\n/**\n * For chunk layouts with finiteRank < 3, returns an adjusted chunk layout where chunk 0 in each\n * non-finite dimension is guaranteed to cover the viewport.\n */\nexport function getNormalizedChunkLayout(\n projectionParameters: ProjectionParameters,\n chunkLayout: ChunkLayout,\n): ChunkLayout {\n const { finiteRank } = chunkLayout;\n if (finiteRank === 3) return chunkLayout;\n tempChunkLayout.finiteRank = finiteRank;\n vec3.copy(tempChunkLayout.size, chunkLayout.size);\n const transform = mat4.copy(tempChunkLayout.transform, chunkLayout.transform);\n const invTransform = mat4.copy(\n tempChunkLayout.invTransform,\n chunkLayout.invTransform,\n );\n tempChunkLayout.detTransform = chunkLayout.detTransform;\n const { invViewMatrix, width, height } = projectionParameters;\n const depth = getViewFrustrumDepthRange(projectionParameters.projectionMat);\n for (let chunkRenderDim = finiteRank; chunkRenderDim < 3; ++chunkRenderDim) {\n // we want to ensure chunk [0] fully covers the viewport\n const offset = invViewMatrix[12 + chunkRenderDim];\n let lower = offset;\n let upper = offset;\n const xc = Math.abs(invViewMatrix[chunkRenderDim] * width);\n lower -= xc;\n upper += xc;\n const yc = Math.abs(invViewMatrix[chunkRenderDim + 4] * height);\n lower -= yc;\n upper += yc;\n const zc = Math.abs(invViewMatrix[chunkRenderDim + 8] * depth);\n lower -= zc;\n upper += zc;\n const scaleFactor = Math.max(1, upper - lower);\n transform[12 + chunkRenderDim] = lower;\n transform[5 * chunkRenderDim] = scaleFactor;\n }\n mat4.invert(invTransform, transform);\n return tempChunkLayout;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { ProjectionParameters } from \"#src/projection_parameters.js\";\nimport type {\n MultiscaleVolumetricDataRenderLayer,\n SliceViewChunkSource,\n SliceViewChunkSpecification,\n TransformedSource,\n} from \"#src/sliceview/base.js\";\nimport { forEachVisibleVolumetricChunk } from \"#src/sliceview/base.js\";\nimport {\n getViewFrustrumVolume,\n mat3,\n mat3FromMat4,\n prod3,\n} from \"#src/util/geom.js\";\n\nexport const ANNOTATION_METADATA_CHUNK_SOURCE_RPC_ID =\n \"annotation.MetadataChunkSource\";\nexport const ANNOTATION_GEOMETRY_CHUNK_SOURCE_RPC_ID =\n \"annotation.GeometryChunkSource\";\nexport const ANNOTATION_SUBSET_GEOMETRY_CHUNK_SOURCE_RPC_ID =\n \"annotation.SubsetGeometryChunkSource\";\nexport const ANNOTATION_REFERENCE_ADD_RPC_ID = \"annotation.reference.add\";\nexport const ANNOTATION_REFERENCE_DELETE_RPC_ID = \"annotation.reference.delete\";\nexport const ANNOTATION_COMMIT_UPDATE_RPC_ID = \"annotation.commit\";\nexport const ANNOTATION_COMMIT_UPDATE_RESULT_RPC_ID = \"annotation.commit\";\n\nexport interface AnnotationGeometryChunkSpecification\n extends SliceViewChunkSpecification {\n /**\n * Must equal the `chunkToMultiscaleTransform` in the `SliceViewSingleResolutionSource`.\n */\n chunkToMultiscaleTransform: Float32Array;\n\n /**\n * Specifies the maximum density of annotations provided by this chunk source, as `limit` per the\n * chunk volume. The higher the value, the sooner chunks from this source will be subsampled. To\n * disable subsampling completely, set `limit` to 0.\n */\n limit: number;\n}\n\nexport const ANNOTATION_SPATIALLY_INDEXED_RENDER_LAYER_RPC_ID =\n \"annotation/SpatiallyIndexedRenderLayer\";\nexport const ANNOTATION_PERSPECTIVE_RENDER_LAYER_UPDATE_SOURCES_RPC_ID =\n \"annotation/PerspectiveRenderLayer:updateSources\";\nexport const ANNOTATION_RENDER_LAYER_RPC_ID = \"annotation/RenderLayer\";\nexport const ANNOTATION_RENDER_LAYER_UPDATE_SEGMENTATION_RPC_ID =\n \"annotation/RenderLayer.updateSegmentation\";\n\nconst tempMat3 = mat3.create();\n\nexport function forEachVisibleAnnotationChunk<\n RLayer extends MultiscaleVolumetricDataRenderLayer,\n Source extends SliceViewChunkSource,\n Transformed extends TransformedSource,\n>(\n projectionParameters: ProjectionParameters,\n localPosition: Float32Array,\n renderScaleTarget: number,\n transformedSources: readonly Transformed[],\n beginScale: (source: Transformed, index: number) => void,\n callback: (\n source: Transformed,\n index: number,\n drawFraction: number,\n physicalSpacing: number,\n pixelSpacing: number,\n ) => void,\n) {\n const {\n displayDimensionRenderInfo,\n viewMatrix,\n projectionMat,\n width,\n height,\n } = projectionParameters;\n const { voxelPhysicalScales } = displayDimensionRenderInfo;\n const viewDet = Math.abs(\n mat3.determinant(mat3FromMat4(tempMat3, viewMatrix)),\n );\n const canonicalToPhysicalScale = prod3(voxelPhysicalScales);\n const viewFrustrumVolume =\n (getViewFrustrumVolume(projectionMat) / viewDet) * canonicalToPhysicalScale;\n\n if (transformedSources.length === 0) return;\n const baseSource = transformedSources[0];\n let sourceVolume =\n Math.abs(baseSource.chunkLayout.detTransform) * canonicalToPhysicalScale;\n const { lowerClipDisplayBound, upperClipDisplayBound } = baseSource;\n for (let i = 0; i < 3; ++i) {\n sourceVolume *= upperClipDisplayBound[i] - lowerClipDisplayBound[i];\n }\n\n const effectiveVolume = Math.min(sourceVolume, viewFrustrumVolume);\n const viewportArea = width * height;\n const targetNumAnnotations = viewportArea / renderScaleTarget ** 2;\n const physicalDensityTarget = targetNumAnnotations / effectiveVolume;\n\n // Target density in annotations per physical volume.\n let totalPhysicalDensity = 0;\n for (\n let scaleIndex = transformedSources.length - 1;\n scaleIndex >= 0 && totalPhysicalDensity < physicalDensityTarget;\n --scaleIndex\n ) {\n const transformedSource = transformedSources[scaleIndex];\n const spec = transformedSource.source\n .spec as AnnotationGeometryChunkSpecification;\n const { chunkLayout } = transformedSource;\n const physicalVolume =\n prod3(chunkLayout.size) *\n Math.abs(chunkLayout.detTransform) *\n canonicalToPhysicalScale;\n const { limit, rank } = spec;\n const { nonDisplayLowerClipBound, nonDisplayUpperClipBound } =\n transformedSource;\n let sliceFraction = 1;\n for (let i = 0; i < rank; ++i) {\n const b = nonDisplayUpperClipBound[i] - nonDisplayLowerClipBound[i];\n if (Number.isFinite(b)) sliceFraction /= b;\n }\n const physicalDensity = (limit * sliceFraction) / physicalVolume;\n\n let firstChunk = true;\n const newTotalPhysicalDensity = totalPhysicalDensity + physicalDensity;\n const totalPhysicalSpacing = (1 / newTotalPhysicalDensity) ** (1 / 3);\n const totalPixelSpacing = Math.sqrt(\n viewportArea / (newTotalPhysicalDensity * effectiveVolume),\n );\n const desiredCount =\n ((physicalDensityTarget - totalPhysicalDensity) * physicalVolume) /\n sliceFraction;\n const drawFraction = Math.min(1, desiredCount / spec.limit);\n forEachVisibleVolumetricChunk(\n projectionParameters,\n localPosition,\n transformedSource,\n () => {\n if (firstChunk) {\n beginScale(transformedSource, scaleIndex);\n firstChunk = false;\n }\n callback(\n transformedSource,\n scaleIndex,\n drawFraction,\n totalPhysicalSpacing,\n totalPixelSpacing,\n );\n },\n );\n totalPhysicalDensity = newTotalPhysicalDensity;\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nexport const glsl_COLORMAPS =\n `vec3 colormapJet(float x) {\n vec3 result;\n result.r = x < 0.89 ? ((x - 0.35) / 0.31) : (1.0 - (x - 0.89) / 0.11 * 0.5);\n result.g = x < 0.64 ? ((x - 0.125) * 4.0) : (1.0 - (x - 0.64) / 0.27);\n result.b = x < 0.34 ? (0.5 + x * 0.5 / 0.11) : (1.0 - (x - 0.34) / 0.31);\n return clamp(result, 0.0, 1.0);\n}\n` +\n /*\n * Adapted from http://www.mrao.cam.ac.uk/~dag/CUBEHELIX/CubeHelix.m\n * which is licensed under http://unlicense.org/\n */\n `vec3 colormapCubehelix(float x) {\n float xclamp = clamp(x, 0.0, 1.0);\n float angle = 2.0 * 3.1415926 * (4.0 / 3.0 + xclamp);\n float amp = xclamp * (1.0 - xclamp) / 2.0;\n vec3 result;\n float cosangle = cos(angle);\n float sinangle = sin(angle);\n result.r = -0.14861 * cosangle + 1.78277 * sinangle;\n result.g = -0.29227 * cosangle + -0.90649 * sinangle;\n result.b = 1.97294 * cosangle;\n result = clamp(xclamp + amp * result, 0.0, 1.0);\n return result;\n}\n`;\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type {\n Annotation,\n AnnotationPropertySpec,\n AnnotationType,\n} from \"#src/annotation/index.js\";\nimport {\n annotationTypeHandlers,\n getPropertyOffsets,\n propertyTypeDataType,\n} from \"#src/annotation/index.js\";\nimport type { AnnotationLayer } from \"#src/annotation/renderlayer.js\";\nimport type { PerspectiveViewRenderContext } from \"#src/perspective_view/render_layer.js\";\nimport type { ChunkDisplayTransformParameters } from \"#src/render_coordinate_transform.js\";\nimport type { SliceViewPanelRenderContext } from \"#src/sliceview/renderlayer.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type { mat4 } from \"#src/util/geom.js\";\nimport type { Buffer } from \"#src/webgl/buffer.js\";\nimport { glsl_COLORMAPS } from \"#src/webgl/colormaps.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type {\n ParameterizedContextDependentShaderGetter,\n WatchableShaderError,\n} from \"#src/webgl/dynamic_shader.js\";\nimport {\n parameterizedEmitterDependentShaderGetter,\n shaderCodeWithLineDirective,\n} from \"#src/webgl/dynamic_shader.js\";\nimport {\n defineInvlerpShaderFunction,\n enableLerpShaderFunction,\n} from \"#src/webgl/lerp.js\";\nimport type { ShaderModule, ShaderProgram } from \"#src/webgl/shader.js\";\nimport { ShaderBuilder } from \"#src/webgl/shader.js\";\nimport type {\n ShaderControlsBuilderState,\n ShaderControlState,\n} from \"#src/webgl/shader_ui_controls.js\";\nimport {\n addControlsToBuilder,\n setControlsInShader,\n} from \"#src/webgl/shader_ui_controls.js\";\n\nconst DEBUG_HISTOGRAMS = false;\n\nexport type AnnotationShaderGetter = ParameterizedContextDependentShaderGetter<\n ShaderModule,\n ShaderControlsBuilderState\n>;\n\nexport interface AnnotationRenderContext {\n buffer: Buffer;\n annotationLayer: AnnotationLayer;\n renderContext: SliceViewPanelRenderContext | PerspectiveViewRenderContext;\n bufferOffset: number;\n count: number;\n basePickId: number;\n selectedIndex: number;\n modelViewProjectionMatrix: mat4;\n subspaceMatrix: Float32Array;\n renderSubspaceModelMatrix: mat4;\n renderSubspaceInvModelMatrix: mat4;\n modelClipBounds: Float32Array;\n chunkDisplayTransform: ChunkDisplayTransformParameters;\n}\n\ninterface AnnotationPropertyTypeRenderHandler {\n defineShader(builder: ShaderBuilder, identifier: string, rank: number): void;\n}\n\nfunction makeSimplePropertyRenderHandler(\n shaderType: string,\n bind: (\n gl: WebGL2RenderingContext,\n location: number,\n stride: number,\n offset: number,\n ) => void,\n) {\n return {\n defineShader(builder: ShaderBuilder, identifier: string) {\n const propName = `prop_${identifier}`;\n const aName = `a_${propName}`;\n builder.addAttribute(`${shaderType}`, aName);\n builder.addVertexCode(`${shaderType} ${propName}() { return ${aName}; }`);\n builder.addInitializer((shader) => {\n const location = shader.attribute(aName);\n const { gl } = shader;\n shader.vertexShaderInputBinders[propName] =\n location === -1\n ? {\n enable() {},\n disable() {},\n bind() {},\n }\n : {\n enable(divisor: number) {\n gl.enableVertexAttribArray(location);\n gl.vertexAttribDivisor(location, divisor);\n },\n disable() {\n gl.vertexAttribDivisor(location, 0);\n gl.disableVertexAttribArray(location);\n },\n bind(stride: number, offset: number) {\n bind(gl, location, stride, offset);\n },\n };\n });\n },\n };\n}\n\nfunction makeFloatPropertyRenderHandler(\n shaderType: string,\n numComponents: number,\n attributeType: number,\n normalized: boolean,\n) {\n return makeSimplePropertyRenderHandler(\n shaderType,\n (gl, location, stride, offset) => {\n gl.vertexAttribPointer(\n location,\n /*size=*/ numComponents,\n /*type=*/ attributeType,\n /*normalized=*/ normalized,\n stride,\n offset,\n );\n },\n );\n}\n\nfunction makeIntegerPropertyRenderHandler(\n shaderType: string,\n numComponents: number,\n attributeType: number,\n) {\n return makeSimplePropertyRenderHandler(\n shaderType,\n (gl, location, stride, offset) => {\n gl.vertexAttribIPointer(\n location,\n /*size=*/ numComponents,\n /*type=*/ attributeType,\n stride,\n offset,\n );\n },\n );\n}\n\nconst annotationPropertyTypeRenderHandlers: {\n [K in AnnotationPropertySpec[\"type\"]]: AnnotationPropertyTypeRenderHandler;\n} = {\n rgb: makeFloatPropertyRenderHandler(\n \"highp vec3\",\n 3,\n WebGL2RenderingContext.UNSIGNED_BYTE,\n /*normalized=*/ true,\n ),\n rgba: makeFloatPropertyRenderHandler(\n \"highp vec4\",\n 4,\n WebGL2RenderingContext.UNSIGNED_BYTE,\n /*normalized=*/ true,\n ),\n float32: makeFloatPropertyRenderHandler(\n \"highp float\",\n 1,\n WebGL2RenderingContext.FLOAT,\n /*normalized=*/ false,\n ),\n uint32: makeIntegerPropertyRenderHandler(\n \"highp uint\",\n 1,\n WebGL2RenderingContext.UNSIGNED_INT,\n ),\n int32: makeIntegerPropertyRenderHandler(\n \"highp int\",\n 1,\n WebGL2RenderingContext.INT,\n ),\n uint16: makeIntegerPropertyRenderHandler(\n \"highp uint\",\n 1,\n WebGL2RenderingContext.UNSIGNED_SHORT,\n ),\n int16: makeIntegerPropertyRenderHandler(\n \"highp int\",\n 1,\n WebGL2RenderingContext.SHORT,\n ),\n uint8: makeIntegerPropertyRenderHandler(\n \"highp uint\",\n 1,\n WebGL2RenderingContext.UNSIGNED_BYTE,\n ),\n int8: makeIntegerPropertyRenderHandler(\n \"highp int\",\n 1,\n WebGL2RenderingContext.BYTE,\n ),\n};\n\nclass AnnotationRenderHelperBase extends RefCounted {\n readonly serializedBytesPerAnnotation: number;\n readonly serializedGeometryBytesPerAnnotation: number;\n readonly propertyOffsets: { group: number; offset: number }[];\n readonly propertyGroupBytes: number[];\n readonly propertyGroupCumulativeBytes: number[];\n readonly geometryDataStride: number;\n\n constructor(\n public gl: GL,\n public annotationType: AnnotationType,\n public rank: number,\n public properties: readonly Readonly[],\n ) {\n super();\n const serializedGeometryBytesPerAnnotation =\n (this.serializedGeometryBytesPerAnnotation =\n annotationTypeHandlers[annotationType].serializedBytes(rank));\n const {\n offsets,\n serializedBytes: serializedBytesPerAnnotation,\n propertyGroupBytes,\n } = getPropertyOffsets(\n rank,\n serializedGeometryBytesPerAnnotation,\n properties,\n );\n this.serializedBytesPerAnnotation = serializedBytesPerAnnotation;\n this.propertyOffsets = offsets;\n this.propertyGroupBytes = propertyGroupBytes;\n this.geometryDataStride = propertyGroupBytes[0];\n const propertyGroupCumulativeBytes = (this.propertyGroupCumulativeBytes =\n new Array(propertyGroupBytes.length));\n propertyGroupCumulativeBytes[0] = 0;\n for (let i = 1; i < propertyGroupBytes.length; ++i) {\n propertyGroupCumulativeBytes[i] =\n propertyGroupCumulativeBytes[i - 1] + propertyGroupBytes[i - 1];\n }\n }\n\n protected defineProperties(\n builder: ShaderBuilder,\n referencedProperties: number[],\n ) {\n const { properties, rank } = this;\n for (const i of referencedProperties) {\n const property = properties[i];\n const handler = annotationPropertyTypeRenderHandlers[property.type];\n handler.defineShader(builder, property.identifier, rank);\n }\n const { propertyOffsets } = this;\n const { propertyGroupBytes, propertyGroupCumulativeBytes } = this;\n builder.addInitializer((shader) => {\n const binders = referencedProperties.map(\n (i) =>\n shader.vertexShaderInputBinders[`prop_${properties[i].identifier}`],\n );\n const numProperties = binders.length;\n shader.vertexShaderInputBinders.properties = {\n enable(divisor: number) {\n for (let i = 0; i < numProperties; ++i) {\n binders[i].enable(divisor);\n }\n },\n bind(stride: number, offset: number) {\n for (let i = 0; i < numProperties; ++i) {\n const { group, offset: propertyOffset } =\n propertyOffsets[referencedProperties[i]];\n binders[i].bind(\n /*stride=*/ propertyGroupBytes[group],\n /*offset=*/ offset +\n propertyOffset +\n propertyGroupCumulativeBytes[group] * stride,\n );\n }\n },\n disable() {\n for (let i = 0; i < numProperties; ++i) {\n binders[i].disable();\n }\n },\n };\n });\n }\n}\n\nexport abstract class AnnotationRenderHelper extends AnnotationRenderHelperBase {\n pickIdsPerInstance: number;\n targetIsSliceView: boolean;\n\n constructor(\n gl: GL,\n annotationType: AnnotationType,\n rank: number,\n properties: readonly Readonly[],\n public shaderControlState: ShaderControlState,\n public fallbackShaderParameters: WatchableValueInterface,\n public shaderError: WatchableShaderError,\n ) {\n super(gl, annotationType, rank, properties);\n }\n\n getDependentShader(\n memoizeKey: any,\n defineShader: (builder: ShaderBuilder) => void,\n ): AnnotationShaderGetter {\n return parameterizedEmitterDependentShaderGetter(this, this.gl, {\n memoizeKey: {\n t: \"annotation\",\n targetIsSliceView: this.targetIsSliceView,\n type: this.annotationType,\n subType: memoizeKey,\n properties: this.properties,\n rank: this.rank,\n },\n fallbackParameters: this.fallbackShaderParameters,\n parameters: this.shaderControlState.builderState,\n shaderError: this.shaderError,\n defineShader: (\n builder: ShaderBuilder,\n parameters: ShaderControlsBuilderState,\n ) => {\n const { rank, properties } = this;\n const referencedProperties: number[] = [];\n const controlsReferencedProperties = parameters.referencedProperties;\n const processedCode = parameters.parseResult.code;\n for (\n let i = 0, numProperties = properties.length;\n i < numProperties;\n ++i\n ) {\n const property = properties[i];\n const functionName = `prop_${property.identifier}`;\n if (\n !controlsReferencedProperties.includes(property.identifier) &&\n !processedCode.match(new RegExp(`\\\\b${functionName}\\\\b`))\n ) {\n continue;\n }\n referencedProperties.push(i);\n }\n this.defineProperties(builder, referencedProperties);\n builder.addUniform(\"highp vec3\", \"uColor\");\n builder.addUniform(\"highp uint\", \"uSelectedIndex\");\n builder.addVarying(\"highp vec4\", \"vColor\");\n // Transform from model coordinates to the rendered subspace.\n builder.addUniform(\"highp vec3\", \"uSubspaceMatrix\", rank);\n // Transform from the rendered subspace of the model coordinate space to clip coordinates.\n builder.addUniform(\"highp mat4\", \"uModelViewProjection\");\n\n // Specifies center vector and per-dimension scale in model coordinates used for\n // clipping.\n builder.addUniform(\"highp float\", \"uModelClipBounds\", rank * 2);\n builder.addUniform(\"highp uint\", \"uPickID\");\n builder.addVarying(\"highp uint\", \"vPickID\", \"flat\");\n\n builder.addVertexCode(glsl_COLORMAPS);\n\n builder.addVertexCode(`\nvec3 defaultColor() { return uColor; }\nhighp uint getPickBaseOffset() { return uint(gl_InstanceID) * ${this.pickIdsPerInstance}u; }\n`);\n\n builder.addFragmentCode(`\nvoid emitAnnotation(vec4 color) {\n emit(color, vPickID);\n}\n`);\n\n const glsl_getSubspaceClipCoefficient = `\nfloat getSubspaceClipCoefficient(float modelPoint[${this.rank}]) {\n float coefficient = 1.0;\n for (int i = 0; i < ${rank}; ++i) {\n float d = abs(modelPoint[i] - uModelClipBounds[i]) * uModelClipBounds[${rank} + i];\n coefficient *= max(0.0, 1.0 - d);\n }\n return coefficient;\n}\n`;\n builder.addVertexCode(glsl_getSubspaceClipCoefficient);\n builder.addFragmentCode(glsl_getSubspaceClipCoefficient);\n builder.addVertexCode(`\nvec3 projectModelVectorToSubspace(float modelPoint[${this.rank}]) {\n vec3 result = vec3(0.0, 0.0, 0.0);\n for (int i = 0; i < ${rank}; ++i) {\n result += uSubspaceMatrix[i] * modelPoint[i];\n }\n return result;\n}\n\nfloat getMaxEndpointSubspaceClipCoefficient(float modelPointA[${this.rank}], float modelPointB[${this.rank}]) {\n float coefficient = 1.0;\n for (int i = 0; i < ${rank}; ++i) {\n float dA = abs(modelPointA[i] - uModelClipBounds[i]) * uModelClipBounds[${rank} + i];\n float dB = abs(modelPointB[i] - uModelClipBounds[i]) * uModelClipBounds[${rank} + i];\n coefficient *= max(0.0, 1.0 - min(dA, dB));\n }\n return coefficient;\n}\n\nfloat getMaxSubspaceClipCoefficient(float modelPointA[${this.rank}], float modelPointB[${this.rank}]) {\n float coefficient = 1.0;\n for (int i = 0; i < ${rank}; ++i) {\n float a = modelPointA[i];\n float b = modelPointB[i];\n float c = uModelClipBounds[i];\n float x = clamp(c, min(a, b), max(a, b));\n float d = abs(x - c) * uModelClipBounds[${rank} + i];\n coefficient *= max(0.0, 1.0 - d);\n }\n return coefficient;\n}\n\n`);\n addControlsToBuilder(parameters, builder);\n builder.addVertexCode(`\nconst bool PROJECTION_VIEW = ${!this.targetIsSliceView};\nbool ng_discardValue;\n#define discard ng_discard()\nvoid ng_discard() {\n ng_discardValue = true;\n}\nvoid setLineColor(vec4 startColor, vec4 endColor);\nvoid setLineWidth(float width);\n\nvoid setEndpointMarkerColor(vec4 startColor, vec4 endColor);\nvoid setEndpointMarkerBorderColor(vec4 startColor, vec4 endColor);\nvoid setEndpointMarkerSize(float startSize, float endSize);\nvoid setEndpointMarkerBorderWidth(float startSize, float endSize);\n\nvoid setPointMarkerColor(vec4 color);\nvoid setPointMarkerColor(vec3 color) { setPointMarkerColor(vec4(color, 1.0)); }\nvoid setPointMarkerBorderColor(vec4 color);\nvoid setPointMarkerSize(float size);\nvoid setPointMarkerBorderWidth(float size);\nvoid setPointMarkerBorderColor(vec3 color) { setPointMarkerBorderColor(vec4(color, 1.0)); }\n\nvoid setEllipsoidFillColor(vec4 color);\n\nvoid setBoundingBoxBorderColor(vec4 color);\nvoid setBoundingBoxBorderWidth(float size);\nvoid setBoundingBoxFillColor(vec4 color);\n\nvoid setEndpointMarkerColor(vec3 startColor, vec3 endColor) {\n setEndpointMarkerColor(vec4(startColor, 1.0), vec4(endColor, 1.0));\n}\nvoid setEndpointMarkerBorderColor(vec3 startColor, vec3 endColor) {\n setEndpointMarkerBorderColor(vec4(startColor, 1.0), vec4(endColor, 1.0));\n}\nvoid setEndpointMarkerColor(vec3 color) { setEndpointMarkerColor(color, color); }\nvoid setEndpointMarkerColor(vec4 color) { setEndpointMarkerColor(color, color); }\nvoid setEndpointMarkerBorderColor(vec3 color) { setEndpointMarkerBorderColor(color, color); }\nvoid setEndpointMarkerBorderColor(vec4 color) { setEndpointMarkerBorderColor(color, color); }\nvoid setEndpointMarkerSize(float size) { setEndpointMarkerSize(size, size); }\nvoid setEndpointMarkerBorderWidth(float size) { setEndpointMarkerBorderWidth(size, size); }\nvoid setLineColor(vec4 color) { setLineColor(color, color); }\nvoid setLineColor(vec3 color) { setLineColor(vec4(color, 1.0)); }\nvoid setLineColor(vec3 startColor, vec3 endColor) { setLineColor(vec4(startColor, 1.0), vec4(endColor, 1.0)); }\nvoid setColor(vec4 color) {\n setPointMarkerColor(color);\n setLineColor(color);\n setEndpointMarkerColor(color);\n setBoundingBoxBorderColor(color);\n setEllipsoidFillColor(vec4(color.rgb, color.a * (PROJECTION_VIEW ? 1.0 : 0.5)));\n}\nvoid setEllipsoidFillColor(vec3 color) { setEllipsoidFillColor(vec4(color, 1.0)); }\n\nvoid setBoundingBoxFillColor(vec3 color) { setBoundingBoxFillColor(vec4(color, 1.0)); }\nvoid setBoundingBoxBorderColor(vec3 color) { setBoundingBoxBorderColor(vec4(color, 1.0)); }\n\nvoid setColor(vec3 color) { setColor(vec4(color, 1.0)); }\nvoid userMain();\n`);\n for (const [\n annotationType,\n renderHandler,\n ] of annotationTypeRenderHandlers) {\n if (annotationType === this.annotationType) continue;\n renderHandler.defineShaderNoOpSetters(builder);\n }\n defineShader(builder);\n builder.addVertexCode(\n \"\\n#define main userMain\\n\" +\n shaderCodeWithLineDirective(parameters.parseResult.code) +\n \"\\n#undef main\\n\",\n );\n },\n });\n }\n\n setPartIndex(builder: ShaderBuilder, ...partIndexExpressions: string[]) {\n let s = `\nvoid setPartIndex(${partIndexExpressions\n .map((_, i) => `highp uint partIndex${i}`)\n .join()}) {\n highp uint pickID = uPickID;\n highp uint pickBaseOffset = getPickBaseOffset();\n${partIndexExpressions\n .map((_, i) => `highp uint pickOffset${i} = pickBaseOffset + partIndex${i};`)\n .join(\"\\n\")}\n`;\n if (partIndexExpressions.length === 0) {\n s += `\n highp uint pickOffset0 = pickBaseOffset;\n`;\n }\n s += `\n vPickID = pickID + pickOffset0;\n highp uint selectedIndex = uSelectedIndex;\nif (selectedIndex == pickBaseOffset${partIndexExpressions\n .map((_, i) => ` || selectedIndex == pickOffset${i}`)\n .join(\"\")}) {\n vColor = vec4(mix(vColor.rgb, vec3(1.0, 1.0, 1.0), 0.75), vColor.a);\n }\n}\n`;\n builder.addVertexCode(s);\n return `setPartIndex(${partIndexExpressions.join()})`;\n }\n\n get invokeUserMain() {\n return `\nng_discardValue = false;\nuserMain();\nif (ng_discardValue) {\n gl_Position = vec4(2.0, 0.0, 0.0, 1.0);\n return;\n}\n`;\n }\n\n getCrossSectionFadeFactor() {\n if (this.targetIsSliceView) {\n return \"(clamp(1.0 - 2.0 * abs(0.5 - gl_FragCoord.z), 0.0, 1.0))\";\n }\n return \"(1.0)\";\n }\n\n enable(\n shaderGetter: AnnotationShaderGetter,\n context: AnnotationRenderContext,\n callback: (shader: ShaderProgram) => void,\n ) {\n const { shader, parameters } = shaderGetter(context.renderContext.emitter);\n if (shader === null) return;\n shader.bind();\n const { gl } = this;\n const { renderContext } = context;\n const { annotationLayer } = context;\n setControlsInShader(\n gl,\n shader,\n this.shaderControlState,\n parameters.parseResult.controls,\n );\n gl.uniform3fv(shader.uniform(\"uSubspaceMatrix\"), context.subspaceMatrix);\n gl.uniform1fv(shader.uniform(\"uModelClipBounds\"), context.modelClipBounds);\n gl.uniformMatrix4fv(\n shader.uniform(\"uModelViewProjection\"),\n false,\n context.modelViewProjectionMatrix,\n );\n if (renderContext.emitPickID) {\n gl.uniform1ui(shader.uniform(\"uPickID\"), context.basePickId);\n }\n if (renderContext.emitColor) {\n const color = annotationLayer.state.displayState.color.value;\n gl.uniform3f(shader.uniform(\"uColor\"), color[0], color[1], color[2]);\n gl.uniform1ui(shader.uniform(\"uSelectedIndex\"), context.selectedIndex);\n }\n\n const binder = shader.vertexShaderInputBinders.properties;\n binder.enable(1);\n gl.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER, context.buffer.buffer);\n binder.bind(/*stride=*/ context.count, context.bufferOffset);\n callback(shader);\n binder.disable();\n }\n\n abstract draw(context: AnnotationRenderContext): void;\n\n private histogramShaders = new Map<\n AnnotationPropertySpec[\"type\"],\n ShaderProgram\n >();\n\n private getHistogramShader(\n propertyType: AnnotationPropertySpec[\"type\"],\n ): ShaderProgram {\n const { histogramShaders } = this;\n let shader = histogramShaders.get(propertyType);\n if (shader === undefined) {\n const { gl } = this;\n shader = gl.memoize.get(\n JSON.stringify({ t: \"propertyHistogramGenerator\", propertyType }),\n () => {\n const builder = new ShaderBuilder(gl);\n this.defineHistogramShader(builder, propertyType);\n return builder.build();\n },\n );\n histogramShaders.set(propertyType, shader);\n }\n return shader;\n }\n\n private defineHistogramShader(\n builder: ShaderBuilder,\n propertyType: AnnotationPropertySpec[\"type\"],\n ) {\n const handler = annotationPropertyTypeRenderHandlers[propertyType];\n // TODO(jbms): If rank-dependent properties are added, this will need to change to support\n // histograms.\n handler.defineShader(builder, \"histogram\", /*rank=*/ 0);\n builder.addOutputBuffer(\"vec4\", \"out_histogram\", 0);\n const invlerpName = \"invlerpForHistogram\";\n const dataType = propertyTypeDataType[propertyType]!;\n builder.addVertexCode(\n defineInvlerpShaderFunction(\n builder,\n invlerpName,\n dataType,\n /*clamp=*/ false,\n ),\n );\n builder.setVertexMain(`\nfloat x = invlerpForHistogram(prop_histogram());\nif (x < 0.0) x = 0.0;\nelse if (x > 1.0) x = 1.0;\nelse x = (1.0 + x * 253.0) / 255.0;\ngl_Position = vec4(2.0 * (x * 255.0 + 0.5) / 256.0 - 1.0, 0.0, 0.0, 1.0);\ngl_PointSize = 1.0;\n`);\n builder.setFragmentMain(\"out_histogram = vec4(1.0, 1.0, 1.0, 1.0);\");\n }\n\n computeHistograms(context: AnnotationRenderContext, frameNumber: number) {\n const { histogramSpecifications } = this.shaderControlState;\n const histogramProperties = histogramSpecifications.properties.value;\n const numHistograms = histogramProperties.length;\n const { properties } = this;\n const numProperties = properties.length;\n const { propertyOffsets } = this;\n const { propertyGroupBytes, propertyGroupCumulativeBytes } = this;\n const { gl } = this;\n gl.enable(WebGL2RenderingContext.BLEND);\n gl.disable(WebGL2RenderingContext.SCISSOR_TEST);\n gl.disable(WebGL2RenderingContext.DEPTH_TEST);\n gl.blendFunc(WebGL2RenderingContext.ONE, WebGL2RenderingContext.ONE);\n const outputFramebuffers = histogramSpecifications.getFramebuffers(gl);\n const oldFrameNumber = histogramSpecifications.frameNumber;\n histogramSpecifications.frameNumber = frameNumber;\n gl.bindBuffer(WebGL2RenderingContext.ARRAY_BUFFER, context.buffer.buffer);\n for (\n let histogramIndex = 0;\n histogramIndex < numHistograms;\n ++histogramIndex\n ) {\n const propertyIdentifier = histogramProperties[histogramIndex];\n for (\n let propertyIndex = 0;\n propertyIndex < numProperties;\n ++propertyIndex\n ) {\n const property = properties[propertyIndex];\n if (property.identifier !== propertyIdentifier) continue;\n const propertyType = property.type;\n const dataType = propertyTypeDataType[propertyType]!;\n const shader = this.getHistogramShader(propertyType);\n shader.bind();\n const binder = shader.vertexShaderInputBinders.prop_histogram;\n binder.enable(0);\n const { group, offset: propertyOffset } =\n propertyOffsets[propertyIndex];\n enableLerpShaderFunction(\n shader,\n \"invlerpForHistogram\",\n dataType,\n histogramSpecifications.bounds.value[histogramIndex],\n );\n binder.bind(\n /*stride=*/ propertyGroupBytes[group],\n /*offset=*/ context.bufferOffset +\n propertyOffset +\n propertyGroupCumulativeBytes[group] * context.count,\n );\n outputFramebuffers[histogramIndex].bind(256, 1);\n if (frameNumber !== oldFrameNumber) {\n gl.clearColor(0, 0, 0, 0);\n gl.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT);\n }\n gl.drawArrays(WebGL2RenderingContext.POINTS, 0, context.count);\n if (DEBUG_HISTOGRAMS) {\n const tempBuffer = new Float32Array(256 * 4);\n gl.readPixels(\n 0,\n 0,\n 256,\n 1,\n WebGL2RenderingContext.RGBA,\n WebGL2RenderingContext.FLOAT,\n tempBuffer,\n );\n const tempBuffer2 = new Float32Array(256);\n for (let j = 0; j < 256; ++j) {\n tempBuffer2[j] = tempBuffer[j * 4];\n }\n console.log(\"histogram\", tempBuffer2.join(\" \"));\n }\n binder.disable();\n break;\n }\n }\n gl.disable(WebGL2RenderingContext.BLEND);\n }\n}\n\ninterface AnnotationRenderHelperConstructor {\n new (\n gl: GL,\n annotationType: AnnotationType,\n rank: number,\n properties: readonly Readonly[],\n shaderControlState: ShaderControlState,\n fallbackShaderParameters: WatchableValueInterface,\n shaderError: WatchableShaderError,\n ): AnnotationRenderHelper;\n}\n\ninterface AnnotationTypeRenderHandler {\n defineShaderNoOpSetters: (builder: ShaderBuilder) => void;\n perspectiveViewRenderHelper: AnnotationRenderHelperConstructor;\n sliceViewRenderHelper: AnnotationRenderHelperConstructor;\n pickIdsPerInstance: number;\n getRepresentativePoint(\n out: Float32Array,\n annotation: T,\n partIndex: number,\n ): void;\n updateViaRepresentativePoint(\n oldAnnotation: T,\n position: Float32Array,\n partIndex: number,\n ): T;\n snapPosition(\n position: Float32Array,\n data: ArrayBuffer,\n offset: number,\n partIndex: number,\n ): void;\n}\n\nconst annotationTypeRenderHandlers = new Map<\n AnnotationType,\n AnnotationTypeRenderHandler\n>();\n\nexport function registerAnnotationTypeRenderHandler(\n type: AnnotationType,\n handler: AnnotationTypeRenderHandler,\n) {\n annotationTypeRenderHandlers.set(type, handler);\n}\n\nexport function getAnnotationTypeRenderHandler(\n type: AnnotationType,\n): AnnotationTypeRenderHandler {\n return annotationTypeRenderHandlers.get(type)!;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type {\n ChunkSourceParametersConstructor,\n LayerChunkProgressInfo,\n} from \"#src/chunk_manager/base.js\";\nimport {\n CHUNK_LAYER_STATISTICS_RPC_ID,\n CHUNK_MANAGER_RPC_ID,\n CHUNK_QUEUE_MANAGER_RPC_ID,\n CHUNK_SOURCE_INVALIDATE_RPC_ID,\n ChunkState,\n REQUEST_CHUNK_STATISTICS_RPC_ID,\n} from \"#src/chunk_manager/base.js\";\nimport { SharedWatchableValue } from \"#src/shared_watchable_value.js\";\nimport { TrackableBoolean } from \"#src/trackable_boolean.js\";\nimport { TrackableValue } from \"#src/trackable_value.js\";\nimport type { CancellationToken } from \"#src/util/cancellation.js\";\nimport { CANCELED } from \"#src/util/cancellation.js\";\nimport type { Borrowed } from \"#src/util/disposable.js\";\nimport { stableStringify } from \"#src/util/json.js\";\nimport { StringMemoize } from \"#src/util/memoize.js\";\nimport { getObjectId } from \"#src/util/object_id.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { RPC, RPCPromise } from \"#src/worker_rpc.js\";\nimport {\n registerPromiseRPC,\n registerRPC,\n registerSharedObjectOwner,\n SharedObject,\n} from \"#src/worker_rpc.js\";\n\nconst DEBUG_CHUNK_UPDATES = false;\n\nexport class Chunk {\n state = ChunkState.SYSTEM_MEMORY;\n constructor(public source: ChunkSource) {}\n\n get gl() {\n return this.source.gl;\n }\n\n copyToGPU(_gl: GL) {\n this.state = ChunkState.GPU_MEMORY;\n }\n\n freeGPUMemory(_gl: GL) {\n this.state = ChunkState.SYSTEM_MEMORY;\n }\n}\n\nfunction validateLimitValue(x: any) {\n if (typeof x !== \"number\" || x < 0) {\n throw new Error(\n `Expected non-negative number as limit, but received: ${JSON.stringify(\n x,\n )}`,\n );\n }\n return x;\n}\n\nexport class CapacitySpecification {\n sizeLimit: TrackableValue;\n itemLimit: TrackableValue;\n constructor({\n defaultItemLimit = Number.POSITIVE_INFINITY,\n defaultSizeLimit = Number.POSITIVE_INFINITY,\n } = {}) {\n this.sizeLimit = new TrackableValue(\n defaultSizeLimit,\n validateLimitValue,\n );\n this.itemLimit = new TrackableValue(\n defaultItemLimit,\n validateLimitValue,\n );\n }\n}\n\nexport interface FrameNumberCounter {\n frameNumber: number;\n changed: NullarySignal;\n}\n\n@registerSharedObjectOwner(CHUNK_QUEUE_MANAGER_RPC_ID)\nexport class ChunkQueueManager extends SharedObject {\n visibleChunksChanged = new NullarySignal();\n pendingChunkUpdates: any = null;\n pendingChunkUpdatesTail: any = null;\n\n /**\n * If non-null, deadline in milliseconds since epoch after which chunk copies to the GPU may not\n * start (until the next frame).\n */\n chunkUpdateDeadline: number | null = null;\n\n chunkUpdateDelay = 30;\n\n enablePrefetch = new TrackableBoolean(true, true);\n\n constructor(\n rpc: RPC,\n public gl: GL,\n public frameNumberCounter: FrameNumberCounter,\n public capacities: {\n gpuMemory: CapacitySpecification;\n systemMemory: CapacitySpecification;\n download: CapacitySpecification;\n compute: CapacitySpecification;\n },\n ) {\n super();\n\n const makeCapacityCounterparts = (capacity: CapacitySpecification) => {\n return {\n itemLimit: this.registerDisposer(\n SharedWatchableValue.makeFromExisting(rpc, capacity.itemLimit),\n ).rpcId,\n sizeLimit: this.registerDisposer(\n SharedWatchableValue.makeFromExisting(rpc, capacity.sizeLimit),\n ).rpcId,\n };\n };\n\n this.initializeCounterpart(rpc, {\n gpuMemoryCapacity: makeCapacityCounterparts(capacities.gpuMemory),\n systemMemoryCapacity: makeCapacityCounterparts(capacities.systemMemory),\n downloadCapacity: makeCapacityCounterparts(capacities.download),\n computeCapacity: makeCapacityCounterparts(capacities.compute),\n enablePrefetch: this.registerDisposer(\n SharedWatchableValue.makeFromExisting(rpc, this.enablePrefetch),\n ).rpcId,\n });\n }\n\n scheduleChunkUpdate() {\n const deadline = this.chunkUpdateDeadline;\n let delay: number;\n if (deadline === null || Date.now() < deadline) {\n delay = 0;\n } else {\n delay = this.chunkUpdateDelay;\n }\n setTimeout(this.processPendingChunkUpdates.bind(this), delay);\n }\n processPendingChunkUpdates(flush = false) {\n let deadline = this.chunkUpdateDeadline;\n if (!flush && deadline === null) {\n deadline = Date.now() + 30;\n }\n let visibleChunksChanged = false;\n let numUpdates = 0;\n while (true) {\n if (!flush && Date.now() > deadline!) {\n // No time to perform chunk update now, we will wait some more.\n this.chunkUpdateDeadline = null;\n setTimeout(\n () => this.processPendingChunkUpdates(),\n this.chunkUpdateDelay,\n );\n break;\n }\n const update = this.pendingChunkUpdates;\n if (update == null) break;\n try {\n if (this.applyChunkUpdate(update)) {\n visibleChunksChanged = true;\n }\n } finally {\n ++numUpdates;\n const nextUpdate = (this.pendingChunkUpdates = update.nextUpdate);\n if (nextUpdate == null) {\n this.pendingChunkUpdatesTail = null;\n break;\n }\n }\n }\n if (visibleChunksChanged) {\n this.visibleChunksChanged.dispatch();\n }\n return numUpdates;\n }\n\n private handleFetch_(source: ChunkSource, update: any) {\n const { resolve, reject, cancellationToken } = update.promise;\n if ((cancellationToken).isCanceled) {\n reject(CANCELED);\n return;\n }\n\n const key = update.key;\n const chunk = source.chunks.get(key);\n if (!chunk) {\n reject(\n new Error(\n `No chunk found at ${key} for source ${source.constructor.name}`,\n ),\n );\n return;\n }\n\n const data = (chunk).data;\n if (!data) {\n reject(\n new Error(\n `At ${key} for source ${source.constructor.name}: chunk has no data`,\n ),\n );\n return;\n }\n\n resolve({ value: data });\n }\n\n applyChunkUpdate(update: any) {\n let visibleChunksChanged = false;\n const { rpc } = this;\n const source = rpc!.get(update.source);\n if (source === undefined) {\n // Source was removed while chunk update was enqueued.\n return;\n }\n if (DEBUG_CHUNK_UPDATES) {\n console.log(\n `${Date.now()} Chunk.update processed: ${source.rpcId} ` +\n `${update.id} ${update.state}`,\n );\n }\n if (update.promise !== undefined) {\n this.handleFetch_(source, update);\n } else if (update.id === undefined) {\n // Invalidate source.\n for (const chunkKey of source.chunks.keys()) {\n source.deleteChunk(chunkKey);\n }\n visibleChunksChanged = true;\n } else {\n const newState: number = update.state;\n if (newState === ChunkState.EXPIRED) {\n // FIXME: maybe use freeList for chunks here\n source.deleteChunk(update.id);\n } else {\n let chunk: Chunk;\n const key = update.id;\n if (update.new) {\n chunk = source.getChunk(update);\n source.addChunk(key, chunk);\n } else {\n chunk = source.chunks.get(key)!;\n }\n const oldState = chunk.state;\n if (newState !== oldState) {\n switch (newState) {\n case ChunkState.GPU_MEMORY:\n chunk.copyToGPU(this.gl);\n if (chunk.constructor.name !== \"ManifestChunk\") {\n visibleChunksChanged = true;\n }\n break;\n case ChunkState.SYSTEM_MEMORY:\n if (oldState === ChunkState.GPU_MEMORY) {\n chunk.freeGPUMemory(this.gl);\n }\n break;\n default:\n throw new Error(\n `INTERNAL ERROR: Invalid chunk state: ${ChunkState[newState]}`,\n );\n }\n }\n if (newState <= ChunkState.SYSTEM_MEMORY) {\n const { chunkRequesters } = source;\n if (chunkRequesters !== undefined) {\n const requesters = chunkRequesters.get(key);\n if (requesters !== undefined) {\n for (const requester of requesters) {\n requester(chunk);\n }\n }\n }\n }\n }\n }\n return visibleChunksChanged;\n }\n\n flushPendingChunkUpdates(): number {\n return this.processPendingChunkUpdates(true);\n }\n\n async getStatistics(): Promise> {\n const rpc = this.rpc!;\n const rawData = await rpc.promiseInvoke>(\n REQUEST_CHUNK_STATISTICS_RPC_ID,\n { queue: this.rpcId },\n );\n const data = new Map();\n for (const [id, statistics] of rawData) {\n const source = rpc.get(id) as ChunkSource | undefined;\n if (source === undefined) continue;\n data.set(source, statistics);\n }\n return data;\n }\n}\n\nfunction updateChunk(rpc: RPC, x: any) {\n const source: ChunkSource = rpc.get(x.source);\n if (DEBUG_CHUNK_UPDATES) {\n console.log(\n `${Date.now()} Chunk.update received: ` +\n `${source.rpcId} ${x.id} ${x.state} with chunkDataSize ${x.chunkDataSize}`,\n );\n }\n const queueManager = source.chunkManager.chunkQueueManager;\n if (source.immediateChunkUpdates) {\n if (queueManager.applyChunkUpdate(x)) {\n queueManager.visibleChunksChanged.dispatch();\n }\n return;\n }\n\n const pendingTail = queueManager.pendingChunkUpdatesTail;\n if (pendingTail == null) {\n queueManager.pendingChunkUpdates = x;\n queueManager.pendingChunkUpdatesTail = x;\n queueManager.scheduleChunkUpdate();\n } else {\n pendingTail.nextUpdate = x;\n queueManager.pendingChunkUpdatesTail = x;\n }\n}\n\nregisterRPC(\"Chunk.update\", function (x) {\n updateChunk(this, x);\n});\n\nregisterPromiseRPC(\n \"Chunk.retrieve\",\n function (x, cancellationToken): RPCPromise {\n return new Promise<{ value: any }>((resolve, reject) => {\n x.promise = { resolve, reject, cancellationToken };\n updateChunk(this, x);\n });\n },\n);\n\nregisterRPC(CHUNK_LAYER_STATISTICS_RPC_ID, function (x) {\n const chunkManager = this.get(x.id) as ChunkManager;\n for (const stats of chunkManager.prevStatisticsLayers) {\n stats.numVisibleChunksNeeded = 0;\n stats.numVisibleChunksAvailable = 0;\n stats.numPrefetchChunksNeeded = 0;\n stats.numPrefetchChunksAvailable = 0;\n }\n chunkManager.prevStatisticsLayers.length = 0;\n for (const layerUpdate of x.layers) {\n const layer = this.get(layerUpdate.id) as ChunkRenderLayerFrontend;\n if (layer === undefined) continue;\n const stats = layer.layerChunkProgressInfo;\n stats.numVisibleChunksAvailable = layerUpdate.numVisibleChunksAvailable;\n stats.numVisibleChunksNeeded = layerUpdate.numVisibleChunksNeeded;\n stats.numPrefetchChunksAvailable = layerUpdate.numPrefetchChunksAvailable;\n stats.numPrefetchChunksNeeded = layerUpdate.numPrefetchChunksNeeded;\n chunkManager.prevStatisticsLayers.push(stats);\n }\n chunkManager.layerChunkStatisticsUpdated.dispatch();\n});\n\nexport type GettableChunkSource = SharedObject & { OPTIONS: object; key: any };\n\nexport interface ChunkSourceConstructor<\n T extends GettableChunkSource = GettableChunkSource,\n> {\n new (...args: any[]): T;\n encodeOptions(options: T[\"OPTIONS\"]): any;\n}\n\n@registerSharedObjectOwner(CHUNK_MANAGER_RPC_ID)\nexport class ChunkManager extends SharedObject {\n memoize = new StringMemoize();\n\n prevStatisticsLayers: LayerChunkProgressInfo[] = [];\n layerChunkStatisticsUpdated = new NullarySignal();\n\n get gl() {\n return this.chunkQueueManager.gl;\n }\n\n constructor(public chunkQueueManager: ChunkQueueManager) {\n super();\n this.registerDisposer(chunkQueueManager.addRef());\n this.initializeCounterpart(chunkQueueManager.rpc!, {\n chunkQueueManager: chunkQueueManager.rpcId,\n });\n }\n\n getChunkSource(\n constructorFunction: ChunkSourceConstructor,\n options: T[\"OPTIONS\"],\n ): T {\n const keyObject = constructorFunction.encodeOptions(options);\n keyObject.constructorId = getObjectId(constructorFunction);\n const key = stableStringify(keyObject);\n return this.memoize.get(key, () => {\n const newSource = new constructorFunction(this, options);\n newSource.initializeCounterpart(this.rpc!, {});\n newSource.key = keyObject;\n return newSource;\n });\n }\n}\n\nexport interface ChunkRequesterState {\n (chunk: Chunk): void;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging\nexport class ChunkSource extends SharedObject {\n OPTIONS: object;\n chunks = new Map();\n\n chunkRequesters: Map | undefined;\n\n /**\n * If set to true, chunk updates will be applied to this source immediately, rather than queueing\n * them. Sources that dynamically update chunks and need to ensure a consistent order of\n * processing relative to other messages between the frontend and worker should set this to true.\n */\n immediateChunkUpdates = false;\n\n constructor(\n public chunkManager: Borrowed,\n _options: object = {},\n ) {\n super();\n }\n\n initializeCounterpart(rpc: RPC, options: any) {\n options.chunkManager = this.chunkManager.rpcId;\n super.initializeCounterpart(rpc, options);\n }\n\n get gl() {\n return this.chunkManager.chunkQueueManager.gl;\n }\n\n deleteChunk(key: string) {\n const chunk = this.chunks.get(key)!;\n if (chunk.state === ChunkState.GPU_MEMORY) {\n chunk.freeGPUMemory(this.gl);\n }\n this.chunks.delete(key);\n }\n\n addChunk(key: string, chunk: Chunk) {\n this.chunks.set(key, chunk);\n }\n\n /**\n * Default implementation for use with backendOnly chunk sources.\n */\n getChunk(_x: any): Chunk {\n throw new Error(\"Not implemented.\");\n }\n\n /**\n * Invalidates the chunk cache. Operates asynchronously.\n */\n invalidateCache(): void {\n this.rpc!.invoke(CHUNK_SOURCE_INVALIDATE_RPC_ID, { id: this.rpcId });\n }\n\n static encodeOptions(_options: object): { [key: string]: any } {\n return {};\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging\nexport interface ChunkSource {\n key: any;\n}\n\nexport function WithParameters<\n Parameters,\n TBase extends ChunkSourceConstructor,\n>(\n Base: TBase,\n parametersConstructor: ChunkSourceParametersConstructor,\n) {\n type WithParametersOptions = InstanceType[\"OPTIONS\"] & {\n parameters: Parameters;\n };\n @registerSharedObjectOwner(parametersConstructor.RPC_ID)\n class C extends Base {\n OPTIONS: WithParametersOptions;\n parameters: Parameters;\n constructor(...args: any[]) {\n super(...args);\n const options: WithParametersOptions = args[1];\n this.parameters = options.parameters;\n }\n initializeCounterpart(rpc: RPC, options: any) {\n options.parameters = this.parameters;\n super.initializeCounterpart(rpc, options);\n }\n static encodeOptions(options: WithParametersOptions) {\n return Object.assign(\n { parameters: options.parameters },\n Base.encodeOptions(options),\n );\n }\n }\n return C;\n}\n\nexport class ChunkRenderLayerFrontend extends SharedObject {\n constructor(public layerChunkProgressInfo: LayerChunkProgressInfo) {\n super();\n }\n}\n\nexport type ChunkStatistics = Map;\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { VisibleSegmentEquivalencePolicy } from \"#src/segmentation_graph/segment_id.js\";\nimport type { SharedDisjointUint64Sets } from \"#src/shared_disjoint_sets.js\";\nimport type { SharedWatchableValue } from \"#src/shared_watchable_value.js\";\nimport type { Uint64OrderedSet } from \"#src/uint64_ordered_set.js\";\nimport type { Uint64Set } from \"#src/uint64_set.js\";\nimport type { RefCounted } from \"#src/util/disposable.js\";\nimport type { Uint64 } from \"#src/util/uint64.js\";\n\nexport interface VisibleSegmentsState {\n visibleSegments: Uint64Set;\n selectedSegments: Uint64OrderedSet;\n segmentEquivalences: SharedDisjointUint64Sets;\n\n // Specifies a temporary/alternative set of segments/equivalences to use for display purposes,\n // used for previewing a merge/split.\n temporaryVisibleSegments: Uint64Set;\n temporarySegmentEquivalences: SharedDisjointUint64Sets;\n useTemporaryVisibleSegments: SharedWatchableValue;\n useTemporarySegmentEquivalences: SharedWatchableValue;\n}\n\nexport const VISIBLE_SEGMENTS_STATE_PROPERTIES = [\n \"visibleSegments\",\n \"segmentEquivalences\",\n \"temporaryVisibleSegments\",\n \"temporarySegmentEquivalences\",\n \"useTemporaryVisibleSegments\",\n \"useTemporarySegmentEquivalences\",\n] as const;\n\nexport function onVisibleSegmentsStateChanged(\n context: RefCounted,\n state: VisibleSegmentsState,\n callback: () => void,\n) {\n context.registerDisposer(state.visibleSegments.changed.add(callback));\n context.registerDisposer(state.segmentEquivalences.changed.add(callback));\n}\n\nexport function onTemporaryVisibleSegmentsStateChanged(\n context: RefCounted,\n state: VisibleSegmentsState,\n callback: () => void,\n) {\n context.registerDisposer(\n state.temporaryVisibleSegments.changed.add(callback),\n );\n context.registerDisposer(\n state.temporarySegmentEquivalences.changed.add(callback),\n );\n context.registerDisposer(\n state.useTemporaryVisibleSegments.changed.add(callback),\n );\n context.registerDisposer(\n state.useTemporarySegmentEquivalences.changed.add(callback),\n );\n}\n\n/**\n * Returns a string key for identifying a uint64 object id. This is faster than\n * Uint64.prototype.toString().\n */\nexport function getObjectKey(objectId: Uint64): string {\n return `${objectId.low},${objectId.high}`;\n}\n\nfunction isHighBitSegment(segmentId: Uint64): boolean {\n return segmentId.high >>> 31 ? true : false;\n}\n\nexport function getVisibleSegments(state: VisibleSegmentsState) {\n return state.useTemporaryVisibleSegments.value\n ? state.temporaryVisibleSegments\n : state.visibleSegments;\n}\n\nexport function getSegmentEquivalences(state: VisibleSegmentsState) {\n return state.useTemporarySegmentEquivalences.value\n ? state.temporarySegmentEquivalences\n : state.segmentEquivalences;\n}\n\nexport function forEachVisibleSegment(\n state: VisibleSegmentsState,\n callback: (objectId: Uint64, rootObjectId: Uint64) => void,\n) {\n const visibleSegments = getVisibleSegments(state);\n const segmentEquivalences = getSegmentEquivalences(state);\n const equivalencePolicy =\n segmentEquivalences.disjointSets.visibleSegmentEquivalencePolicy.value;\n for (const rootObjectId of visibleSegments.unsafeKeys()) {\n if (\n equivalencePolicy &\n VisibleSegmentEquivalencePolicy.NONREPRESENTATIVE_EXCLUDED\n ) {\n const rootObjectId2 = segmentEquivalences.get(rootObjectId);\n callback(rootObjectId, rootObjectId2);\n } else {\n // TODO(jbms): Remove this check if logic is added to ensure that it always holds.\n if (!segmentEquivalences.disjointSets.isMinElement(rootObjectId)) {\n continue;\n }\n for (const objectId of segmentEquivalences.setElements(rootObjectId)) {\n if (\n equivalencePolicy &\n VisibleSegmentEquivalencePolicy.REPRESENTATIVE_EXCLUDED &&\n equivalencePolicy &\n VisibleSegmentEquivalencePolicy.MAX_REPRESENTATIVE &&\n isHighBitSegment(objectId)\n ) {\n continue;\n }\n callback(objectId, rootObjectId);\n }\n }\n }\n}\n\nexport interface IndexedSegmentProperty {\n id: string;\n type: \"string\";\n description: string | undefined;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { TrackableValue } from \"#src/trackable_value.js\";\nimport { makeVerifyNumberInInterval } from \"#src/util/json.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport { VisibilityPriorityAggregator } from \"#src/visibility_priority/frontend.js\";\n\nexport const numRenderScaleHistogramBins = 40;\nexport const renderScaleHistogramBinSize = 0.5;\nexport const renderScaleHistogramOrigin = -4;\n\nexport function getRenderScaleHistogramOffset(\n renderScale: number,\n origin: number = renderScaleHistogramOrigin,\n): number {\n return (Math.log2(renderScale) - origin) / renderScaleHistogramBinSize;\n}\n\nexport function getRenderScaleFromHistogramOffset(\n offset: number,\n origin: number = renderScaleHistogramOrigin,\n): number {\n return 2 ** (offset * renderScaleHistogramBinSize + origin);\n}\n\nexport function trackableRenderScaleTarget(\n initialValue: number,\n scaleOrigin: number = 2 ** renderScaleHistogramOrigin,\n scaleMax?: number,\n) {\n if (scaleMax === undefined) {\n scaleMax =\n 2 **\n Math.round(\n renderScaleHistogramBinSize * numRenderScaleHistogramBins +\n renderScaleHistogramOrigin,\n ) -\n 1;\n }\n const verifyNumberInInterval = makeVerifyNumberInInterval(\n scaleOrigin,\n scaleMax,\n );\n return new TrackableValue(initialValue, verifyNumberInInterval);\n}\n\nexport class RenderScaleHistogram {\n visibility = new VisibilityPriorityAggregator();\n changed = new NullarySignal();\n logScaleOrigin: number;\n\n constructor(origin: number = renderScaleHistogramOrigin) {\n this.logScaleOrigin = origin;\n }\n\n /**\n * Frame number corresponding to the current histogram.\n */\n frameNumber = -1;\n\n /**\n * Maps from spatial scale (nanometers) to histogram row index in the range\n * `[0, spatialScales.size)`.\n */\n spatialScales = new Map();\n\n /**\n * Current number of rows allocated for the histogram.\n */\n numHistogramRows = 1;\n\n /**\n * Initially allocate one row.\n */\n value = new Uint32Array(\n numRenderScaleHistogramBins * this.numHistogramRows * 2,\n );\n\n /**\n * Number of chunks that are indication only (not present in the data).\n */\n fakeChunkCount = 0;\n\n begin(frameNumber: number) {\n if (frameNumber !== this.frameNumber) {\n this.value.fill(0);\n this.frameNumber = frameNumber;\n this.spatialScales.clear();\n this.fakeChunkCount = 0;\n this.changed.dispatch();\n }\n }\n\n /**\n * Adds a count to the histogram.\n *\n * @param spatialScale Spatial resolution of data in nanometers.\n * @param renderScale Rendered scale of data in screen pixels.\n * @param presentCount Number of present chunks.\n * @param notPresentCount Number of desired but not-present chunks.\n * @param renderOnly If true, indicates that the added bar is for display only, and is not linked\n * to actual chunk loading stats. Defaults to false.\n */\n add(\n spatialScale: number,\n renderScale: number,\n presentCount: number,\n notPresentCount: number,\n renderOnly = false,\n ) {\n let { spatialScales, numHistogramRows, value } = this;\n let spatialScaleIndex = spatialScales.get(spatialScale);\n if (spatialScaleIndex === undefined) {\n spatialScaleIndex = spatialScales.size;\n spatialScales.set(spatialScale, spatialScaleIndex);\n }\n if (spatialScaleIndex >= numHistogramRows) {\n this.numHistogramRows = numHistogramRows *= 2;\n const newValue = new Uint32Array(\n numHistogramRows * numRenderScaleHistogramBins * 2,\n );\n newValue.set(value);\n this.value = value = newValue;\n }\n const index =\n spatialScaleIndex * numRenderScaleHistogramBins * 2 +\n Math.min(\n Math.max(\n 0,\n Math.round(\n getRenderScaleHistogramOffset(renderScale, this.logScaleOrigin),\n ),\n ),\n numRenderScaleHistogramBins - 1,\n );\n value[index] += presentCount;\n value[index + numRenderScaleHistogramBins] += notPresentCount;\n if (renderOnly) {\n this.fakeChunkCount = this.fakeChunkCount + notPresentCount;\n }\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { ChunkManager } from \"#src/chunk_manager/frontend.js\";\nimport { ChunkRenderLayerFrontend } from \"#src/chunk_manager/frontend.js\";\nimport type { CoordinateSpace } from \"#src/coordinate_transform.js\";\nimport type { VisibleLayerInfo } from \"#src/layer/index.js\";\nimport type {\n ChunkTransformParameters,\n RenderLayerTransformOrError,\n} from \"#src/render_coordinate_transform.js\";\nimport type { RenderScaleHistogram } from \"#src/render_scale_statistics.js\";\nimport { trackableRenderScaleTarget } from \"#src/render_scale_statistics.js\";\nimport type {\n ThreeDimensionalReadyRenderContext,\n ThreeDimensionalRenderContext,\n} from \"#src/renderlayer.js\";\nimport { RenderLayer, VisibilityTrackedRenderLayer } from \"#src/renderlayer.js\";\nimport { SharedWatchableValue } from \"#src/shared_watchable_value.js\";\nimport type {\n SliceViewBase,\n SliceViewProjectionParameters,\n SliceViewSourceOptions,\n TransformedSource,\n} from \"#src/sliceview/base.js\";\nimport {\n filterVisibleSources,\n SLICEVIEW_RENDERLAYER_RPC_ID,\n} from \"#src/sliceview/base.js\";\nimport type {\n MultiscaleSliceViewChunkSource,\n SliceView,\n SliceViewChunkSource,\n SliceViewSingleResolutionSource,\n} from \"#src/sliceview/frontend.js\";\nimport type { SliceViewPanel } from \"#src/sliceview/panel.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { constantWatchableValue } from \"#src/trackable_value.js\";\nimport type { Borrowed } from \"#src/util/disposable.js\";\nimport { HistogramSpecifications } from \"#src/webgl/empirical_cdf.js\";\nimport type { ShaderModule } from \"#src/webgl/shader.js\";\nimport type { RpcId, SharedObject } from \"#src/worker_rpc.js\";\n\nexport interface SliceViewRenderLayerOptions {\n /**\n * Specifies the transform from the \"model\" coordinate space (specified by the multiscale source)\n * to the \"render layer\" coordinate space.\n */\n transform: WatchableValueInterface;\n renderScaleTarget?: WatchableValueInterface;\n renderScaleHistogram?: RenderScaleHistogram;\n\n /**\n * Specifies the position within the \"local\" coordinate space.\n */\n localPosition: WatchableValueInterface;\n dataHistogramSpecifications?: HistogramSpecifications;\n\n rpcTransfer?: { [index: string]: number | string | null };\n}\n\nexport interface VisibleSourceInfo {\n source: Borrowed;\n refCount: number;\n chunkTransform: ChunkTransformParameters;\n}\n\nexport interface SliceViewRenderContext {\n sliceView: SliceView;\n projectionParameters: SliceViewProjectionParameters;\n wireFrame: boolean;\n}\n\nexport abstract class SliceViewRenderLayer<\n Source extends SliceViewChunkSource = SliceViewChunkSource,\n SourceOptions extends SliceViewSourceOptions = SliceViewSourceOptions,\n> extends RenderLayer {\n rpcId: RpcId | null = null;\n rpcTransfer: { [index: string]: number | string | null } = {};\n\n localPosition: WatchableValueInterface;\n channelCoordinateSpace: WatchableValueInterface;\n transform: WatchableValueInterface;\n\n renderScaleTarget: WatchableValueInterface;\n renderScaleHistogram?: RenderScaleHistogram;\n\n // This is only used by `ImageRenderLayer` currently, but is defined here because\n // `sliceview/frontend.ts` is responsible for providing the texture buffers used for accumulating\n // histograms.\n dataHistogramSpecifications: HistogramSpecifications;\n\n getDataHistogramCount() {\n return this.dataHistogramSpecifications.visibleHistograms;\n }\n\n /**\n * Currently visible sources for this render layer.\n */\n private visibleSources = new Map<\n Borrowed,\n VisibleSourceInfo\n >();\n\n /**\n * Cached list of sources in `visibleSources`, ordered by voxel size.\n *\n * Truncated to zero length when `visibleSources` changes to indicate that it is invalid.\n */\n private visibleSourcesList_: VisibleSourceInfo[] = [];\n\n getSources(\n options: SliceViewSourceOptions,\n ): SliceViewSingleResolutionSource[][] {\n return this.multiscaleSource.getSources(options as any);\n }\n\n addSource(\n source: Borrowed,\n chunkTransform: ChunkTransformParameters,\n ) {\n const { visibleSources } = this;\n const info = visibleSources.get(source);\n if (info !== undefined) {\n ++info.refCount;\n info.chunkTransform = chunkTransform;\n } else {\n visibleSources.set(source, { source, refCount: 1, chunkTransform });\n this.visibleSourcesList_.length = 0;\n }\n }\n\n removeSource(source: Borrowed) {\n const { visibleSources } = this;\n const info = visibleSources.get(source)!;\n if (info.refCount !== 1) {\n --info.refCount;\n } else {\n visibleSources.delete(source);\n this.visibleSourcesList_.length = 0;\n }\n }\n\n get visibleSourcesList() {\n const { visibleSources, visibleSourcesList_ } = this;\n if (visibleSourcesList_.length === 0 && visibleSources.size !== 0) {\n for (const info of visibleSources.values()) {\n visibleSourcesList_.push(info);\n }\n // Sort by volume scaling factor.\n visibleSourcesList_.sort((a, b) => {\n return (\n Math.abs(a.chunkTransform.chunkToLayerTransformDet) -\n Math.abs(b.chunkTransform.chunkToLayerTransformDet)\n );\n });\n }\n return visibleSourcesList_;\n }\n\n constructor(\n public chunkManager: ChunkManager,\n public multiscaleSource: MultiscaleSliceViewChunkSource<\n Source,\n SourceOptions\n >,\n options: SliceViewRenderLayerOptions,\n ) {\n super();\n\n const { renderScaleTarget = trackableRenderScaleTarget(1) } = options;\n this.renderScaleTarget = renderScaleTarget;\n this.renderScaleHistogram = options.renderScaleHistogram;\n this.transform = options.transform;\n this.localPosition = options.localPosition;\n this.rpcTransfer = options.rpcTransfer || {};\n this.dataHistogramSpecifications = this.registerDisposer(\n options.dataHistogramSpecifications ??\n new HistogramSpecifications(\n constantWatchableValue([]),\n constantWatchableValue([]),\n constantWatchableValue([]),\n ),\n );\n this.registerDisposer(\n this.dataHistogramSpecifications.visibility.changed.add(\n this.redrawNeeded.dispatch,\n ),\n );\n }\n\n RPC_TYPE_ID: string;\n\n initializeCounterpart() {\n const sharedObject = this.registerDisposer(\n new ChunkRenderLayerFrontend(this.layerChunkProgressInfo),\n );\n const rpc = this.chunkManager.rpc!;\n sharedObject.RPC_TYPE_ID = this.RPC_TYPE_ID;\n sharedObject.initializeCounterpart(rpc, {\n localPosition: this.registerDisposer(\n SharedWatchableValue.makeFromExisting(rpc, this.localPosition),\n ).rpcId,\n renderScaleTarget: this.registerDisposer(\n SharedWatchableValue.makeFromExisting(rpc, this.renderScaleTarget),\n ).rpcId,\n ...this.rpcTransfer,\n });\n this.rpcId = sharedObject.rpcId;\n }\n\n get gl() {\n return this.chunkManager.chunkQueueManager.gl;\n }\n\n setGLBlendMode(gl: WebGL2RenderingContext, renderLayerNum: number): void {\n // Default blend mode for non-blend-mode-aware layers\n if (renderLayerNum > 0) {\n gl.enable(WebGL2RenderingContext.BLEND);\n gl.blendFunc(\n WebGL2RenderingContext.SRC_ALPHA,\n WebGL2RenderingContext.ONE_MINUS_SRC_ALPHA,\n );\n } else {\n gl.disable(WebGL2RenderingContext.BLEND);\n }\n }\n\n abstract draw(renderContext: SliceViewRenderContext): void;\n\n filterVisibleSources(\n sliceView: SliceViewBase,\n sources: readonly TransformedSource[],\n ): Iterable {\n return filterVisibleSources(sliceView, this, sources);\n }\n}\n\nSliceViewRenderLayer.prototype.RPC_TYPE_ID = SLICEVIEW_RENDERLAYER_RPC_ID;\n\nexport interface SliceViewPanelReadyRenderContext\n extends ThreeDimensionalReadyRenderContext {\n sliceView: SliceView;\n}\n\nexport interface SliceViewPanelRenderContext\n extends SliceViewPanelReadyRenderContext,\n ThreeDimensionalRenderContext {\n emitter: ShaderModule;\n\n /**\n * Specifies whether the emitted color value will be used.\n */\n emitColor: boolean;\n\n /**\n * Specifies whether the emitted pick ID will be used.\n */\n emitPickID: boolean;\n}\n\nexport class SliceViewPanelRenderLayer<\n AttachmentState = unknown,\n> extends VisibilityTrackedRenderLayer {\n draw(\n renderContext: SliceViewPanelRenderContext,\n attachment: VisibleLayerInfo,\n ) {\n renderContext;\n attachment;\n // Must be overridden by subclasses.\n }\n\n isReady(\n renderContext: SliceViewPanelReadyRenderContext,\n attachment: VisibleLayerInfo,\n ) {\n renderContext;\n attachment;\n return true;\n }\n\n backend: SharedObject | undefined;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { debounce } from \"lodash-es\";\nimport { ChunkState } from \"#src/chunk_manager/base.js\";\nimport type {\n ChunkManager,\n ChunkRequesterState,\n} from \"#src/chunk_manager/frontend.js\";\nimport { Chunk, ChunkSource } from \"#src/chunk_manager/frontend.js\";\nimport { applyRenderViewportToProjectionMatrix } from \"#src/display_context.js\";\nimport type { LayerManager } from \"#src/layer/index.js\";\nimport type {\n DisplayDimensionRenderInfo,\n NavigationState,\n} from \"#src/navigation_state.js\";\nimport { updateProjectionParametersFromInverseViewAndProjection } from \"#src/projection_parameters.js\";\nimport type {\n ChunkDisplayTransformParameters,\n ChunkTransformParameters,\n RenderLayerTransformOrError,\n} from \"#src/render_coordinate_transform.js\";\nimport {\n getChunkDisplayTransformParameters,\n getChunkTransformParameters,\n getLayerDisplayDimensionMapping,\n} from \"#src/render_coordinate_transform.js\";\nimport {\n DerivedProjectionParameters,\n SharedProjectionParameters,\n} from \"#src/renderlayer.js\";\nimport type {\n SliceViewChunkSource as SliceViewChunkSourceInterface,\n SliceViewChunkSpecification,\n SliceViewSourceOptions,\n TransformedSource,\n VisibleLayerSources,\n} from \"#src/sliceview/base.js\";\nimport {\n forEachPlaneIntersectingVolumetricChunk,\n getNormalizedChunkLayout,\n SLICEVIEW_ADD_VISIBLE_LAYER_RPC_ID,\n SLICEVIEW_REMOVE_VISIBLE_LAYER_RPC_ID,\n SLICEVIEW_REQUEST_CHUNK_RPC_ID,\n SLICEVIEW_RPC_ID,\n SliceViewBase,\n SliceViewProjectionParameters,\n} from \"#src/sliceview/base.js\";\nimport { ChunkLayout } from \"#src/sliceview/chunk_layout.js\";\nimport { SliceViewRenderLayer } from \"#src/sliceview/renderlayer.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport type { CancellationToken } from \"#src/util/cancellation.js\";\nimport { uncancelableToken } from \"#src/util/cancellation.js\";\nimport type { Borrowed, Disposer, Owned } from \"#src/util/disposable.js\";\nimport { invokeDisposers, RefCounted } from \"#src/util/disposable.js\";\nimport type { vec4 } from \"#src/util/geom.js\";\nimport { kOneVec, kZeroVec4, mat4, vec3 } from \"#src/util/geom.js\";\nimport { MessageList, MessageSeverity } from \"#src/util/message_list.js\";\nimport { getObjectId } from \"#src/util/object_id.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport { withSharedVisibility } from \"#src/visibility_priority/frontend.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { HistogramSpecifications } from \"#src/webgl/empirical_cdf.js\";\nimport { TextureHistogramGenerator } from \"#src/webgl/empirical_cdf.js\";\nimport type { TextureBuffer } from \"#src/webgl/offscreen.js\";\nimport {\n DepthTextureBuffer,\n FramebufferConfiguration,\n makeTextureBuffers,\n} from \"#src/webgl/offscreen.js\";\nimport type { ShaderModule, ShaderProgram } from \"#src/webgl/shader.js\";\nimport { ShaderBuilder } from \"#src/webgl/shader.js\";\nimport { getSquareCornersBuffer } from \"#src/webgl/square_corners_buffer.js\";\nimport type { RPC } from \"#src/worker_rpc.js\";\nimport { registerSharedObjectOwner } from \"#src/worker_rpc.js\";\n\nexport type GenericChunkKey = string;\n\nclass FrontendSliceViewBase extends SliceViewBase<\n SliceViewChunkSource,\n SliceViewRenderLayer,\n FrontendTransformedSource\n> {}\nconst Base = withSharedVisibility(FrontendSliceViewBase);\n\nexport interface FrontendTransformedSource<\n RLayer extends SliceViewRenderLayer = SliceViewRenderLayer,\n Source extends SliceViewChunkSource = SliceViewChunkSource,\n> extends TransformedSource {\n chunkTransform: ChunkTransformParameters;\n chunkDisplayTransform: ChunkDisplayTransformParameters;\n}\n\ninterface FrontendVisibleLayerSources\n extends VisibleLayerSources<\n SliceViewRenderLayer,\n SliceViewChunkSource,\n FrontendTransformedSource\n > {\n transformGeneration: number;\n lastSeenGeneration: number;\n disposers: Disposer[];\n messages: MessageList;\n}\n\nfunction serializeTransformedSource(\n tsource: TransformedSource,\n) {\n return {\n source: tsource.source.addCounterpartRef(),\n effectiveVoxelSize: tsource.effectiveVoxelSize,\n layerRank: tsource.layerRank,\n nonDisplayLowerClipBound: tsource.nonDisplayLowerClipBound,\n nonDisplayUpperClipBound: tsource.nonDisplayUpperClipBound,\n lowerClipBound: tsource.lowerClipBound,\n upperClipBound: tsource.upperClipBound,\n lowerClipDisplayBound: tsource.lowerClipDisplayBound,\n upperClipDisplayBound: tsource.upperClipDisplayBound,\n chunkDisplayDimensionIndices: tsource.chunkDisplayDimensionIndices,\n lowerChunkDisplayBound: tsource.lowerChunkDisplayBound,\n upperChunkDisplayBound: tsource.upperChunkDisplayBound,\n fixedLayerToChunkTransform: tsource.fixedLayerToChunkTransform,\n combinedGlobalLocalToChunkTransform:\n tsource.combinedGlobalLocalToChunkTransform,\n chunkLayout: tsource.chunkLayout.toObject(),\n };\n}\n\nexport function serializeAllTransformedSources(\n allSources: TransformedSource[][],\n) {\n return allSources.map((scales) => scales.map(serializeTransformedSource));\n}\n\nfunction disposeTransformedSources(\n layer: SliceViewRenderLayer,\n allSources: TransformedSource[][],\n) {\n for (const scales of allSources) {\n for (const { source } of scales) {\n layer.removeSource(source);\n source.dispose();\n }\n }\n}\n\n@registerSharedObjectOwner(SLICEVIEW_RPC_ID)\nexport class SliceView extends Base {\n gl = this.chunkManager.gl;\n viewChanged = new NullarySignal();\n rpc: RPC;\n rpcId: number;\n\n renderingStale = true;\n\n visibleChunksStale = true;\n\n visibleLayerList = new Array();\n\n visibleLayers: Map;\n\n offscreenFramebuffer = this.registerDisposer(\n new FramebufferConfiguration(this.gl, {\n colorBuffers: makeTextureBuffers(this.gl, 1),\n depthBuffer: new DepthTextureBuffer(this.gl),\n }),\n );\n histogramInputTextures: TextureBuffer[] = [];\n offscreenFramebuffersWithHistograms = [this.offscreenFramebuffer];\n\n get displayDimensionRenderInfo() {\n return this.navigationState.displayDimensionRenderInfo;\n }\n\n private histogramGenerator = TextureHistogramGenerator.get(this.gl);\n\n computeHistograms(\n count: number,\n histogramSpecifications: HistogramSpecifications,\n ) {\n this.histogramGenerator.compute(\n count,\n this.offscreenFramebuffer.depthBuffer!.texture,\n this.histogramInputTextures,\n histogramSpecifications,\n this.chunkManager.chunkQueueManager.frameNumberCounter.frameNumber,\n );\n }\n\n projectionParameters: Owned<\n DerivedProjectionParameters\n >;\n\n sharedProjectionParameters: Owned<\n SharedProjectionParameters\n >;\n\n flushBackendProjectionParameters() {\n this.sharedProjectionParameters.flush();\n }\n\n constructor(\n public chunkManager: ChunkManager,\n public layerManager: LayerManager,\n public navigationState: Owned,\n public wireFrame: WatchableValueInterface,\n ) {\n super(\n new DerivedProjectionParameters({\n parametersConstructor: SliceViewProjectionParameters,\n navigationState,\n update: (out, navigationState) => {\n const { invViewMatrix, centerDataPosition } = out;\n navigationState.toMat4(invViewMatrix);\n const { canonicalVoxelFactors, voxelPhysicalScales } =\n out.displayDimensionRenderInfo;\n for (let i = 0; i < 3; ++i) {\n centerDataPosition[i] = invViewMatrix[12 + i];\n }\n const {\n logicalWidth,\n logicalHeight,\n projectionMat,\n viewportNormalInGlobalCoordinates,\n viewportNormalInCanonicalCoordinates,\n } = out;\n const { relativeDepthRange } = navigationState;\n mat4.ortho(\n projectionMat,\n -logicalWidth / 2,\n logicalWidth / 2,\n logicalHeight / 2,\n -logicalHeight / 2,\n -relativeDepthRange,\n relativeDepthRange,\n );\n applyRenderViewportToProjectionMatrix(out, projectionMat);\n updateProjectionParametersFromInverseViewAndProjection(out);\n const { viewMatrix } = out;\n for (let i = 0; i < 3; ++i) {\n const x = (viewportNormalInGlobalCoordinates[i] =\n viewMatrix[i * 4 + 2]);\n viewportNormalInCanonicalCoordinates[i] =\n x / canonicalVoxelFactors[i];\n }\n vec3.normalize(\n viewportNormalInGlobalCoordinates,\n viewportNormalInGlobalCoordinates,\n );\n vec3.normalize(\n viewportNormalInCanonicalCoordinates,\n viewportNormalInCanonicalCoordinates,\n );\n\n let newPixelSize = 0;\n for (let i = 0; i < 3; ++i) {\n const s = voxelPhysicalScales[i];\n const x = invViewMatrix[i];\n newPixelSize += (s * x) ** 2;\n }\n newPixelSize = Math.sqrt(newPixelSize);\n out.pixelSize = newPixelSize;\n },\n }),\n );\n this.registerDisposer(navigationState);\n this.registerDisposer(this.projectionParameters);\n this.registerDisposer(\n this.projectionParameters.changed.add((oldValue, newValue) => {\n if (\n oldValue.displayDimensionRenderInfo !==\n newValue.displayDimensionRenderInfo\n ) {\n this.updateVisibleLayers();\n }\n }),\n );\n const rpc = this.chunkManager.rpc!;\n const sharedProjectionParameters = (this.sharedProjectionParameters =\n this.registerDisposer(\n new SharedProjectionParameters(rpc, this.projectionParameters),\n ));\n this.initializeCounterpart(rpc, {\n chunkManager: chunkManager.rpcId,\n projectionParameters: sharedProjectionParameters.rpcId,\n });\n this.registerDisposer(\n layerManager.layersChanged.add(() => {\n this.updateVisibleLayers();\n }),\n );\n\n this.wireFrame.changed.add(this.viewChanged.dispatch);\n\n this.viewChanged.add(() => {\n this.renderingStale = true;\n });\n this.registerDisposer(\n chunkManager.chunkQueueManager.visibleChunksChanged.add(\n this.viewChanged.dispatch,\n ),\n );\n this.updateVisibleLayers();\n }\n\n forEachVisibleChunk(\n tsource: FrontendTransformedSource,\n chunkLayout: ChunkLayout,\n callback: (key: string) => void,\n ) {\n forEachPlaneIntersectingVolumetricChunk(\n this.projectionParameters.value,\n tsource.renderLayer.localPosition.value,\n tsource,\n chunkLayout,\n () => {\n callback(tsource.curPositionInChunks.join());\n },\n );\n }\n\n isReady() {\n if (!this.navigationState.valid) {\n return false;\n }\n this.updateVisibleLayers.flush();\n this.updateVisibleSources();\n let numValidChunks = 0;\n let totalChunks = 0;\n for (const { visibleSources } of this.visibleLayers.values()) {\n for (const tsource of visibleSources) {\n const chunkLayout = getNormalizedChunkLayout(\n this.projectionParameters.value,\n tsource.chunkLayout,\n );\n const { source } = tsource;\n const { chunks } = source;\n this.forEachVisibleChunk(tsource, chunkLayout, (key) => {\n const chunk = chunks.get(key);\n ++totalChunks;\n if (chunk && chunk.state === ChunkState.GPU_MEMORY) {\n ++numValidChunks;\n }\n });\n }\n }\n return numValidChunks === totalChunks;\n }\n\n private updateVisibleLayers = this.registerCancellable(\n debounce(() => {\n this.updateVisibleLayersNow();\n }, 0),\n );\n\n invalidateVisibleSources() {\n super.invalidateVisibleSources();\n this.viewChanged.dispatch();\n }\n\n private bindVisibleRenderLayer(\n renderLayer: SliceViewRenderLayer,\n disposers: Disposer[],\n ) {\n disposers.push(\n renderLayer.localPosition.changed.add(() =>\n this.invalidateVisibleChunks(),\n ),\n );\n disposers.push(renderLayer.redrawNeeded.add(this.viewChanged.dispatch));\n disposers.push(renderLayer.transform.changed.add(this.updateVisibleLayers));\n disposers.push(\n renderLayer.renderScaleTarget.changed.add(() =>\n this.invalidateVisibleSources(),\n ),\n );\n const { renderScaleHistogram } = renderLayer;\n if (renderScaleHistogram !== undefined) {\n disposers.push(renderScaleHistogram.visibility.add(this.visibility));\n }\n disposers.push(\n renderLayer.dataHistogramSpecifications.producerVisibility.add(\n this.visibility,\n ),\n );\n }\n\n private updateVisibleLayersNow() {\n if (this.wasDisposed) {\n return false;\n }\n if (!this.navigationState.valid) return false;\n // Used to determine which layers are no longer visible.\n const curUpdateGeneration = Date.now();\n const { visibleLayers, visibleLayerList } = this;\n const { displayDimensionRenderInfo } = this.projectionParameters.value;\n const rpc = this.rpc!;\n const rpcMessage: any = { id: this.rpcId };\n let changed = false;\n visibleLayerList.length = 0;\n for (const renderLayer of this.layerManager.readyRenderLayers()) {\n if (renderLayer instanceof SliceViewRenderLayer) {\n visibleLayerList.push(renderLayer);\n let layerInfo = visibleLayers.get(renderLayer);\n if (layerInfo === undefined) {\n const disposers: Disposer[] = [];\n const messages = new MessageList();\n layerInfo = {\n messages,\n allSources: this.getTransformedSources(renderLayer, messages),\n transformGeneration: renderLayer.transform.changed.count,\n visibleSources: [],\n disposers,\n lastSeenGeneration: curUpdateGeneration,\n displayDimensionRenderInfo,\n };\n disposers.push(renderLayer.messages.addChild(layerInfo.messages));\n visibleLayers.set(renderLayer.addRef(), layerInfo);\n this.bindVisibleRenderLayer(renderLayer, disposers);\n } else {\n layerInfo.lastSeenGeneration = curUpdateGeneration;\n const curTransformGeneration = renderLayer.transform.changed.count;\n if (\n layerInfo.transformGeneration === curTransformGeneration &&\n layerInfo.displayDimensionRenderInfo === displayDimensionRenderInfo\n ) {\n continue;\n }\n const allSources = layerInfo.allSources;\n layerInfo.allSources = this.getTransformedSources(\n renderLayer,\n layerInfo.messages,\n );\n disposeTransformedSources(renderLayer, allSources);\n layerInfo.visibleSources.length = 0;\n layerInfo.displayDimensionRenderInfo = displayDimensionRenderInfo;\n layerInfo.transformGeneration = curTransformGeneration;\n }\n rpcMessage.layerId = renderLayer.rpcId;\n rpcMessage.sources = serializeAllTransformedSources(\n layerInfo.allSources,\n );\n rpcMessage.displayDimensionRenderInfo = displayDimensionRenderInfo;\n this.flushBackendProjectionParameters();\n rpc.invoke(SLICEVIEW_ADD_VISIBLE_LAYER_RPC_ID, rpcMessage);\n changed = true;\n }\n }\n for (const [renderLayer, layerInfo] of visibleLayers) {\n if (layerInfo.lastSeenGeneration === curUpdateGeneration) continue;\n rpcMessage.layerId = renderLayer.rpcId;\n rpc.invoke(SLICEVIEW_REMOVE_VISIBLE_LAYER_RPC_ID, rpcMessage);\n visibleLayers.delete(renderLayer);\n disposeTransformedSources(renderLayer, layerInfo.allSources);\n invokeDisposers(layerInfo.disposers);\n renderLayer.dispose();\n changed = true;\n }\n if (changed) {\n this.visibleSourcesStale = true;\n }\n // Unconditionally call viewChanged, because layers may have been reordered even if the set of\n // sources is the same.\n this.viewChanged.dispatch();\n return changed;\n }\n\n invalidateVisibleChunks() {\n super.invalidateVisibleChunks();\n this.viewChanged.dispatch();\n }\n\n get valid() {\n return this.navigationState.valid;\n }\n\n private getOffscreenFramebufferWithHistograms(count: number) {\n const { offscreenFramebuffersWithHistograms } = this;\n let framebuffer = offscreenFramebuffersWithHistograms[count];\n if (framebuffer === undefined) {\n const { gl, histogramInputTextures, offscreenFramebuffer } = this;\n if (histogramInputTextures.length < count) {\n histogramInputTextures.push(\n ...makeTextureBuffers(\n gl,\n count - histogramInputTextures.length,\n WebGL2RenderingContext.R8,\n WebGL2RenderingContext.RED,\n ),\n );\n }\n const colorBuffers = [offscreenFramebuffer.colorBuffers[0].addRef()];\n for (let i = 0; i < count; ++i) {\n colorBuffers.push(histogramInputTextures[i].addRef());\n }\n framebuffer = this.registerDisposer(\n new FramebufferConfiguration(gl, {\n colorBuffers,\n depthBuffer: offscreenFramebuffer.depthBuffer!.addRef(),\n }),\n );\n offscreenFramebuffersWithHistograms[count] = framebuffer;\n }\n return framebuffer;\n }\n\n updateRendering() {\n const projectionParameters = this.projectionParameters.value;\n const { width, height } = projectionParameters;\n if (!this.renderingStale || !this.valid || width === 0 || height === 0) {\n return;\n }\n this.renderingStale = false;\n this.updateVisibleLayers.flush();\n this.updateVisibleSources();\n\n const { gl, offscreenFramebuffer } = this;\n\n offscreenFramebuffer.bind(width, height);\n gl.disable(gl.SCISSOR_TEST);\n\n gl.clearColor(0, 0, 0, 0);\n gl.colorMask(true, true, true, true);\n gl.clear(WebGL2RenderingContext.COLOR_BUFFER_BIT);\n let renderLayerNum = 0;\n const wireFrame = this.wireFrame.value;\n const renderContext = { sliceView: this, projectionParameters, wireFrame };\n for (const renderLayer of this.visibleLayerList) {\n const histogramCount = wireFrame\n ? 0\n : renderLayer.getDataHistogramCount();\n const framebuffer =\n this.getOffscreenFramebufferWithHistograms(histogramCount);\n framebuffer.bind(width, height);\n for (let i = 0; i < histogramCount; ++i) {\n gl.clearBufferfv(WebGL2RenderingContext.COLOR, 1 + i, kZeroVec4);\n }\n gl.enable(WebGL2RenderingContext.DEPTH_TEST);\n gl.depthFunc(WebGL2RenderingContext.LESS);\n gl.clearDepth(1);\n gl.clear(WebGL2RenderingContext.DEPTH_BUFFER_BIT);\n renderLayer.setGLBlendMode(gl, renderLayerNum);\n renderLayer.draw(renderContext);\n ++renderLayerNum;\n }\n gl.disable(WebGL2RenderingContext.BLEND);\n gl.disable(WebGL2RenderingContext.DEPTH_TEST);\n offscreenFramebuffer.unbind();\n }\n\n disposed() {\n for (const [renderLayer, layerInfo] of this.visibleLayers) {\n disposeTransformedSources(renderLayer, layerInfo.allSources);\n invokeDisposers(layerInfo.disposers);\n renderLayer.dispose();\n }\n this.visibleLayers.clear();\n this.visibleLayerList.length = 0;\n }\n\n getTransformedSources(\n layer: SliceViewRenderLayer,\n messages: MessageList,\n ): FrontendTransformedSource[][] {\n const transformedSources = getVolumetricTransformedSources(\n this.projectionParameters.value.displayDimensionRenderInfo,\n layer.transform.value,\n (options) => layer.getSources(options),\n messages,\n layer,\n );\n for (const scales of transformedSources) {\n for (const tsource of scales) {\n layer.addSource(tsource.source, tsource.chunkTransform);\n }\n }\n return transformedSources;\n }\n}\n\nexport interface SliceViewChunkSourceOptions<\n Spec extends SliceViewChunkSpecification = SliceViewChunkSpecification,\n> {\n spec: Spec;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging\nexport abstract class SliceViewChunkSource<\n Spec extends SliceViewChunkSpecification = SliceViewChunkSpecification,\n ChunkType extends SliceViewChunk = SliceViewChunk,\n >\n extends ChunkSource\n implements SliceViewChunkSourceInterface\n{\n chunks: Map;\n\n OPTIONS: SliceViewChunkSourceOptions;\n\n spec: Spec;\n\n constructor(\n chunkManager: ChunkManager,\n options: SliceViewChunkSourceOptions,\n ) {\n super(chunkManager, options);\n this.spec = options.spec;\n }\n\n static encodeSpec(spec: SliceViewChunkSpecification) {\n return {\n chunkDataSize: Array.from(spec.chunkDataSize),\n lowerVoxelBound: Array.from(spec.lowerVoxelBound),\n upperVoxelBound: Array.from(spec.upperVoxelBound),\n };\n }\n\n static encodeOptions(options: SliceViewChunkSourceOptions): any {\n const encoding = ChunkSource.encodeOptions(options);\n encoding.spec = SliceViewChunkSource.encodeSpec(options.spec);\n return encoding;\n }\n\n initializeCounterpart(rpc: RPC, options: any) {\n options.spec = this.spec;\n super.initializeCounterpart(rpc, options);\n }\n\n // Requests a chunk by its grid position, and returns the result of `transform(chunk)`, where\n // `transform` is guaranteed to be called while the chunk is present in system memory.\n //\n // The `transform` function is used in place of simply returning the chunk, because it is not\n // possible to guarantee that the chunk remains in system memory by the time the promise resolves.\n async fetchChunk(\n chunkGridPosition: Float32Array,\n transform: (chunk: Chunk) => T,\n cancellationToken: CancellationToken = uncancelableToken,\n ): Promise {\n const key = chunkGridPosition.join();\n const existingChunk = this.chunks.get(key);\n if (\n existingChunk !== undefined &&\n existingChunk.state <= ChunkState.SYSTEM_MEMORY\n ) {\n return transform(existingChunk);\n }\n this.addRef();\n let { chunkRequesters } = this;\n if (chunkRequesters === undefined) {\n chunkRequesters = this.chunkRequesters = new Map();\n }\n let requester: ChunkRequesterState;\n let entry = chunkRequesters!.get(key);\n if (entry === undefined) {\n entry = [];\n chunkRequesters!.set(key, entry);\n }\n const promise = new Promise((resolve) => {\n requester = (chunk) => resolve(transform(chunk));\n entry!.push(requester);\n });\n try {\n await this.rpc!.promiseInvoke(\n SLICEVIEW_REQUEST_CHUNK_RPC_ID,\n { source: this.rpcId, chunkGridPosition },\n cancellationToken,\n );\n return await promise;\n } finally {\n const entryIndex = entry.indexOf(requester!);\n entry.splice(entryIndex, 1);\n if (entry.length === 0) {\n chunkRequesters!.delete(key);\n }\n if (chunkRequesters.size === 0) {\n this.chunkRequesters = undefined;\n }\n this.dispose();\n }\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging\nexport interface SliceViewChunkSource {\n // TODO(jbms): Move this declaration to the class definition above and declare abstract once\n // TypeScript supports mixins with abstact classes.\n getChunk(x: any): any;\n}\n\nexport class SliceViewChunk extends Chunk {\n chunkGridPosition: vec3;\n source: SliceViewChunkSource;\n\n constructor(source: SliceViewChunkSource, x: any) {\n super(source);\n this.chunkGridPosition = x.chunkGridPosition;\n this.state = ChunkState.SYSTEM_MEMORY;\n }\n}\n\n/**\n * Helper for rendering a SliceView that has been pre-rendered to a texture.\n */\nexport class SliceViewRenderHelper extends RefCounted {\n private copyVertexPositionsBuffer = getSquareCornersBuffer(this.gl);\n private shader: ShaderProgram;\n\n private textureCoordinateAdjustment = new Float32Array(4);\n\n constructor(\n public gl: GL,\n emitter: ShaderModule,\n ) {\n super();\n const builder = new ShaderBuilder(gl);\n builder.addVarying(\"vec2\", \"vTexCoord\");\n builder.addUniform(\"sampler2D\", \"uSampler\");\n builder.addInitializer((shader) => {\n gl.uniform1i(shader.uniform(\"uSampler\"), 0);\n });\n builder.addUniform(\"vec4\", \"uColorFactor\");\n builder.addUniform(\"vec4\", \"uBackgroundColor\");\n builder.addUniform(\"mat4\", \"uProjectionMatrix\");\n builder.addUniform(\"vec4\", \"uTextureCoordinateAdjustment\");\n builder.require(emitter);\n builder.setFragmentMain(`\nvec4 sampledColor = texture(uSampler, vTexCoord);\nif (sampledColor.a == 0.0) {\n sampledColor = uBackgroundColor;\n}\nemit(sampledColor * uColorFactor, 0u);\n`);\n builder.addAttribute(\"vec4\", \"aVertexPosition\");\n builder.setVertexMain(`\nvTexCoord = uTextureCoordinateAdjustment.xy + 0.5 * (aVertexPosition.xy + 1.0) * uTextureCoordinateAdjustment.zw;\ngl_Position = uProjectionMatrix * aVertexPosition;\n`);\n this.shader = this.registerDisposer(builder.build());\n }\n\n draw(\n texture: WebGLTexture | null,\n projectionMatrix: mat4,\n colorFactor: vec4,\n backgroundColor: vec4,\n xStart: number,\n yStart: number,\n xEnd: number,\n yEnd: number,\n ) {\n const { gl, shader, textureCoordinateAdjustment } = this;\n textureCoordinateAdjustment[0] = xStart;\n textureCoordinateAdjustment[1] = yStart;\n textureCoordinateAdjustment[2] = xEnd - xStart;\n textureCoordinateAdjustment[3] = yEnd - yStart;\n shader.bind();\n gl.activeTexture(gl.TEXTURE0);\n gl.bindTexture(gl.TEXTURE_2D, texture);\n gl.disable(WebGL2RenderingContext.BLEND);\n gl.uniformMatrix4fv(\n shader.uniform(\"uProjectionMatrix\"),\n false,\n projectionMatrix,\n );\n gl.uniform4fv(shader.uniform(\"uColorFactor\"), colorFactor);\n gl.uniform4fv(shader.uniform(\"uBackgroundColor\"), backgroundColor);\n gl.uniform4fv(\n shader.uniform(\"uTextureCoordinateAdjustment\"),\n textureCoordinateAdjustment,\n );\n\n const aVertexPosition = shader.attribute(\"aVertexPosition\");\n this.copyVertexPositionsBuffer.bindToVertexAttrib(\n aVertexPosition,\n /*components=*/ 2,\n );\n\n gl.drawArrays(gl.TRIANGLE_FAN, 0, 4);\n\n gl.disableVertexAttribArray(aVertexPosition);\n gl.bindTexture(gl.TEXTURE_2D, null);\n }\n\n static get(gl: GL, emitter: ShaderModule) {\n return gl.memoize.get(\n `sliceview/SliceViewRenderHelper:${getObjectId(emitter)}`,\n () => new SliceViewRenderHelper(gl, emitter),\n );\n }\n}\n\nexport interface SliceViewSingleResolutionSource<\n Source extends SliceViewChunkSource = SliceViewChunkSource,\n> {\n chunkSource: Source;\n\n /**\n * (rank + 1)*(rank + 1) homogeneous transformation matrix from the \"chunk\" coordinate space to\n * the MultiscaleSliceViewChunkSource space.\n */\n chunkToMultiscaleTransform: Float32Array;\n\n /**\n * Lower clipping bound in voxels within the \"chunk\" coordinate space. If not specified, defaults\n * to `chunkSource.spec.lowerVoxelBound`. Non-integer values are supported.\n *\n * Both lowerClipBound and upperClipBound are applied during rendering but do not affect which\n * chunks/voxels are actually retrieved. That is determined by lowerVoxelBound and\n * upperVoxelBound of `chunkSource.spec`.\n */\n lowerClipBound?: Float32Array;\n\n /**\n * Upper clipping bound in voxels within the \"chunk\" coordinate space. If not specified, defaults\n * to `chunkSource.spec.upperVoxelBound`.\n */\n upperClipBound?: Float32Array;\n}\n\nexport abstract class MultiscaleSliceViewChunkSource<\n Source extends SliceViewChunkSource = SliceViewChunkSource,\n SourceOptions extends SliceViewSourceOptions = SliceViewSourceOptions,\n> {\n abstract get rank(): number;\n\n /**\n * @return Chunk sources for each scale, ordered by increasing minVoxelSize. Outer array indexes\n * over alternative chunk orientations. The inner array indexes over scale.\n *\n * Every chunk source must have rank equal to `this.rank`.\n */\n abstract getSources(\n options: SourceOptions,\n ): SliceViewSingleResolutionSource[][];\n\n constructor(public chunkManager: Borrowed) {}\n}\n\nexport function getVolumetricTransformedSources(\n displayDimensionRenderInfo: DisplayDimensionRenderInfo,\n transform: RenderLayerTransformOrError,\n getSources: (\n options: SliceViewSourceOptions,\n ) => SliceViewSingleResolutionSource[][],\n messages: MessageList,\n layer: any,\n): FrontendTransformedSource[][] {\n messages.clearMessages();\n const returnError = (message: string) => {\n messages.addMessage({\n severity: MessageSeverity.error,\n message,\n });\n return [];\n };\n if (transform.error !== undefined) {\n return returnError(transform.error);\n }\n const layerRank = transform.rank;\n const chunkRank = transform.unpaddedRank;\n const { displayDimensionIndices, displayRank, canonicalVoxelFactors } =\n displayDimensionRenderInfo;\n const layerDisplayDimensionMapping = getLayerDisplayDimensionMapping(\n transform,\n displayDimensionIndices,\n );\n\n const { displayToLayerDimensionIndices } = layerDisplayDimensionMapping;\n const multiscaleToViewTransform = new Float32Array(displayRank * chunkRank);\n const { modelToRenderLayerTransform } = transform;\n for (let displayDim = 0; displayDim < displayRank; ++displayDim) {\n const layerDim = displayToLayerDimensionIndices[displayDim];\n if (layerDim === -1) continue;\n const factor = canonicalVoxelFactors[displayDim];\n for (let chunkDim = 0; chunkDim < chunkRank; ++chunkDim) {\n multiscaleToViewTransform[displayRank * chunkDim + displayDim] =\n modelToRenderLayerTransform[(layerRank + 1) * chunkDim + layerDim] *\n factor;\n }\n }\n const allSources = getSources({\n displayRank: displayRank,\n multiscaleToViewTransform: multiscaleToViewTransform,\n modelChannelDimensionIndices: transform.channelToRenderLayerDimensions,\n });\n const { voxelPhysicalScales: globalScales } = displayDimensionRenderInfo;\n try {\n const getTransformedSource = (\n singleResolutionSource: SliceViewSingleResolutionSource,\n ): FrontendTransformedSource => {\n const { chunkSource: source } = singleResolutionSource;\n const { spec } = source;\n const {\n lowerClipBound = spec.lowerVoxelBound,\n upperClipBound = spec.upperVoxelBound,\n } = singleResolutionSource;\n const chunkTransform = getChunkTransformParameters(\n transform,\n singleResolutionSource.chunkToMultiscaleTransform,\n );\n const { chunkDataSize } = spec;\n const { channelToChunkDimensionIndices } = chunkTransform;\n const nonDisplayLowerClipBound = new Float32Array(chunkRank);\n const nonDisplayUpperClipBound = new Float32Array(chunkRank);\n nonDisplayLowerClipBound.set(lowerClipBound);\n nonDisplayUpperClipBound.set(upperClipBound);\n const channelRank = channelToChunkDimensionIndices.length;\n const { channelSpaceShape } = transform;\n for (let channelDim = 0; channelDim < channelRank; ++channelDim) {\n const chunkDim = channelToChunkDimensionIndices[channelDim];\n if (chunkDim === -1) continue;\n const size = channelSpaceShape[channelDim];\n if (chunkDataSize[chunkDim] !== size) {\n throw new Error(\n \"Channel dimension \" +\n transform.layerDimensionNames[\n transform.channelToRenderLayerDimensions[channelDim]\n ] +\n ` has extent ${size} but corresponding chunk dimension has extent ` +\n `${chunkDataSize[chunkDim]}`,\n );\n }\n nonDisplayLowerClipBound[chunkDim] = Number.NEGATIVE_INFINITY;\n nonDisplayUpperClipBound[chunkDim] = Number.POSITIVE_INFINITY;\n }\n const chunkDisplayTransform = getChunkDisplayTransformParameters(\n chunkTransform,\n layerDisplayDimensionMapping,\n );\n // Compute `chunkDisplaySize`, and `{lower,upper}ChunkDisplayBound`.\n const lowerChunkDisplayBound = vec3.create();\n const upperChunkDisplayBound = vec3.create();\n const lowerClipDisplayBound = vec3.create();\n const upperClipDisplayBound = vec3.create();\n // Size of chunk in \"display\" coordinate space.\n const chunkDisplaySize = vec3.create();\n const { numChunkDisplayDims, chunkDisplayDimensionIndices } =\n chunkDisplayTransform;\n const {\n combinedGlobalLocalToChunkTransform,\n layerRank,\n combinedGlobalLocalRank,\n } = chunkTransform;\n const fixedLayerToChunkTransform = new Float32Array(\n combinedGlobalLocalToChunkTransform,\n );\n for (\n let chunkDisplayDimIndex = 0;\n chunkDisplayDimIndex < numChunkDisplayDims;\n ++chunkDisplayDimIndex\n ) {\n const chunkDim = chunkDisplayDimensionIndices[chunkDisplayDimIndex];\n for (let i = 0; i <= combinedGlobalLocalRank; ++i) {\n fixedLayerToChunkTransform[chunkDim + i * layerRank] = 0;\n }\n if (chunkDim < chunkRank) {\n chunkDisplaySize[chunkDisplayDimIndex] = spec.chunkDataSize[chunkDim];\n lowerChunkDisplayBound[chunkDisplayDimIndex] =\n spec.lowerChunkBound[chunkDim];\n upperChunkDisplayBound[chunkDisplayDimIndex] =\n spec.upperChunkBound[chunkDim];\n lowerClipDisplayBound[chunkDisplayDimIndex] =\n lowerClipBound[chunkDim];\n upperClipDisplayBound[chunkDisplayDimIndex] =\n upperClipBound[chunkDim];\n nonDisplayLowerClipBound[chunkDim] = Number.NEGATIVE_INFINITY;\n nonDisplayUpperClipBound[chunkDim] = Number.POSITIVE_INFINITY;\n } else {\n chunkDisplaySize[chunkDisplayDimIndex] = 1;\n lowerChunkDisplayBound[chunkDisplayDimIndex] = 0;\n upperChunkDisplayBound[chunkDisplayDimIndex] = 1;\n lowerClipDisplayBound[chunkDisplayDimIndex] = 0;\n upperClipDisplayBound[chunkDisplayDimIndex] = 1;\n }\n }\n chunkDisplaySize.fill(1, numChunkDisplayDims);\n lowerChunkDisplayBound.fill(0, numChunkDisplayDims);\n upperChunkDisplayBound.fill(1, numChunkDisplayDims);\n lowerClipDisplayBound.fill(0, numChunkDisplayDims);\n upperClipDisplayBound.fill(1, numChunkDisplayDims);\n const chunkLayout = new ChunkLayout(\n chunkDisplaySize,\n chunkDisplayTransform.displaySubspaceModelMatrix,\n numChunkDisplayDims,\n );\n // This is an approximation of the voxel size (exact only for permutation/scaling\n // transforms). It would be better to model the voxel as an ellipsiod and find the\n // lengths of the axes.\n const effectiveVoxelSize = chunkLayout.localSpatialVectorToGlobal(\n vec3.create(),\n /*baseVoxelSize=*/ kOneVec,\n );\n for (let i = 0; i < displayRank; ++i) {\n effectiveVoxelSize[i] = Math.abs(\n effectiveVoxelSize[i] * globalScales[i],\n );\n }\n effectiveVoxelSize.fill(1, displayRank);\n return {\n layerRank,\n lowerClipBound,\n upperClipBound,\n nonDisplayLowerClipBound,\n nonDisplayUpperClipBound,\n renderLayer: layer,\n source,\n lowerChunkDisplayBound,\n upperChunkDisplayBound,\n lowerClipDisplayBound,\n upperClipDisplayBound,\n effectiveVoxelSize,\n chunkLayout,\n chunkDisplayDimensionIndices,\n fixedLayerToChunkTransform,\n curPositionInChunks: new Float32Array(chunkRank),\n combinedGlobalLocalToChunkTransform:\n chunkTransform.combinedGlobalLocalToChunkTransform,\n fixedPositionWithinChunk: new Uint32Array(chunkRank),\n chunkTransform,\n chunkDisplayTransform,\n };\n };\n return allSources.map((scales) =>\n scales.map((s) => getTransformedSource(s)),\n );\n } catch (e) {\n // Ensure references are released in the case of an exception.\n for (const scales of allSources) {\n for (const { chunkSource: source } of scales) {\n source.dispose();\n }\n }\n const { globalDimensionNames } = displayDimensionRenderInfo;\n const dimensionDesc = Array.from(\n displayDimensionRenderInfo.displayDimensionIndices.filter(\n (i) => i !== -1,\n ),\n (i) => globalDimensionNames[i],\n ).join(\",\\u00a0\");\n const message = `Cannot render (${dimensionDesc}) cross section: ${e.message}`;\n return returnError(message);\n }\n}\n","/**\n * @license\n * Copyright 2018 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { AnnotationGeometryChunkSpecification } from \"#src/annotation/base.js\";\nimport {\n ANNOTATION_COMMIT_UPDATE_RESULT_RPC_ID,\n ANNOTATION_COMMIT_UPDATE_RPC_ID,\n ANNOTATION_GEOMETRY_CHUNK_SOURCE_RPC_ID,\n ANNOTATION_METADATA_CHUNK_SOURCE_RPC_ID,\n ANNOTATION_REFERENCE_ADD_RPC_ID,\n ANNOTATION_REFERENCE_DELETE_RPC_ID,\n ANNOTATION_SUBSET_GEOMETRY_CHUNK_SOURCE_RPC_ID,\n} from \"#src/annotation/base.js\";\nimport type {\n Annotation,\n AnnotationId,\n AnnotationPropertySerializer,\n AnnotationPropertySpec,\n AnnotationSourceSignals,\n SerializedAnnotations,\n} from \"#src/annotation/index.js\";\nimport {\n AnnotationReference,\n AnnotationType,\n annotationTypeHandlers,\n annotationTypes,\n fixAnnotationAfterStructuredCloning,\n makeAnnotationId,\n makeAnnotationPropertySerializers,\n} from \"#src/annotation/index.js\";\nimport { getAnnotationTypeRenderHandler } from \"#src/annotation/type_handler.js\";\nimport type { ChunkManager } from \"#src/chunk_manager/frontend.js\";\nimport { Chunk, ChunkSource } from \"#src/chunk_manager/frontend.js\";\nimport { getObjectKey } from \"#src/segmentation_display_state/base.js\";\nimport type { SliceViewSourceOptions } from \"#src/sliceview/base.js\";\nimport type {\n MultiscaleSliceViewChunkSource,\n SliceViewChunkSourceOptions,\n SliceViewSingleResolutionSource,\n} from \"#src/sliceview/frontend.js\";\nimport {\n SliceViewChunk,\n SliceViewChunkSource,\n} from \"#src/sliceview/frontend.js\";\nimport { StatusMessage } from \"#src/status.js\";\nimport { WatchableValue } from \"#src/trackable_value.js\";\nimport type { Borrowed, Owned } from \"#src/util/disposable.js\";\nimport { ENDIANNESS, Endianness } from \"#src/util/endian.js\";\nimport * as matrix from \"#src/util/matrix.js\";\nimport type { Signal } from \"#src/util/signal.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport type { Buffer } from \"#src/webgl/buffer.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { RPC } from \"#src/worker_rpc.js\";\nimport {\n registerRPC,\n registerSharedObjectOwner,\n SharedObject,\n} from \"#src/worker_rpc.js\";\n\nexport interface AnnotationGeometryChunkSourceOptions\n extends SliceViewChunkSourceOptions {\n spec: AnnotationGeometryChunkSpecification;\n parent: Borrowed;\n}\n\nexport function computeNumPickIds(\n serializedAnnotations: SerializedAnnotations,\n) {\n let numPickIds = 0;\n const { typeToIds } = serializedAnnotations;\n for (const annotationType of annotationTypes) {\n numPickIds +=\n getAnnotationTypeRenderHandler(annotationType).pickIdsPerInstance *\n typeToIds[annotationType].length;\n }\n return numPickIds;\n}\n\nexport class AnnotationGeometryData {\n buffer: Buffer | undefined;\n bufferValid = false;\n serializedAnnotations: SerializedAnnotations;\n numPickIds = 0;\n\n constructor(x: SerializedAnnotations) {\n this.serializedAnnotations = {\n data: x.data,\n typeToIds: x.typeToIds,\n typeToOffset: x.typeToOffset,\n typeToIdMaps: x.typeToIdMaps,\n };\n }\n freeGPUMemory(gl: GL) {\n gl;\n const { buffer } = this;\n if (buffer !== undefined) {\n buffer.dispose();\n this.bufferValid = false;\n this.buffer = undefined;\n }\n }\n}\n\nexport class AnnotationSubsetGeometryChunk extends Chunk {\n source: AnnotationSubsetGeometryChunkSource;\n // undefined indicates chunk not found\n data: AnnotationGeometryData | undefined;\n constructor(source: AnnotationSubsetGeometryChunkSource, x: any) {\n super(source);\n if (x.data !== undefined) {\n this.data = new AnnotationGeometryData(x);\n }\n }\n\n freeGPUMemory(gl: GL) {\n super.freeGPUMemory(gl);\n const { data } = this;\n if (data !== undefined) {\n data.freeGPUMemory(gl);\n }\n }\n\n dispose() {\n this.data = undefined;\n }\n}\n\nexport class AnnotationGeometryChunk extends SliceViewChunk {\n source: AnnotationGeometryChunkSource;\n // undefined indicates chunk not found\n data: AnnotationGeometryData | undefined;\n\n constructor(source: AnnotationGeometryChunkSource, x: any) {\n super(source, x);\n if (x.data !== undefined) {\n this.data = new AnnotationGeometryData(x);\n }\n }\n\n freeGPUMemory(gl: GL) {\n super.freeGPUMemory(gl);\n const { data } = this;\n if (data !== undefined) {\n data.freeGPUMemory(gl);\n }\n }\n\n dispose() {\n this.data = undefined;\n }\n}\n\n@registerSharedObjectOwner(ANNOTATION_GEOMETRY_CHUNK_SOURCE_RPC_ID)\nexport class AnnotationGeometryChunkSource extends SliceViewChunkSource<\n AnnotationGeometryChunkSpecification,\n AnnotationGeometryChunk\n> {\n OPTIONS: AnnotationGeometryChunkSourceOptions;\n parent: Borrowed;\n immediateChunkUpdates = true;\n\n /**\n * Transforms positions in the MultiscaleAnnotationSource coordinate space to grid cell\n * coordinates. Equal to the inverse of `this.spec.chunkToMultiscaleTransform`, with rows divided\n * by `this.spec.chunkDataSize`.\n */\n multiscaleToChunkTransform: Float32Array;\n\n constructor(\n chunkManager: Borrowed,\n options: AnnotationGeometryChunkSourceOptions,\n ) {\n super(chunkManager, options);\n const parent = (this.parent = options.parent);\n parent.spatiallyIndexedSources.add(this);\n const { rank, chunkDataSize } = this.spec;\n const multiscaleToChunkTransform = (this.multiscaleToChunkTransform =\n new Float32Array((rank + 1) ** 2));\n matrix.inverse(\n multiscaleToChunkTransform,\n rank + 1,\n this.spec.chunkToMultiscaleTransform,\n rank + 1,\n rank + 1,\n );\n for (let i = 0; i < rank; ++i) {\n for (let j = 0; j < rank + 1; ++j) {\n multiscaleToChunkTransform[(rank + 1) * j + i] /= chunkDataSize[i];\n }\n }\n }\n\n disposed() {\n this.parent.spatiallyIndexedSources.delete(this);\n super.disposed();\n }\n\n initializeCounterpart(rpc: RPC, options: any) {\n options.parent = this.parent.rpcId;\n super.initializeCounterpart(rpc, options);\n }\n\n addChunk(key: string, chunk: AnnotationGeometryChunk) {\n super.addChunk(key, chunk);\n // TODO: process local deletions\n }\n\n getChunk(x: any) {\n return new AnnotationGeometryChunk(this, x);\n }\n}\n\n@registerSharedObjectOwner(ANNOTATION_SUBSET_GEOMETRY_CHUNK_SOURCE_RPC_ID)\nexport class AnnotationSubsetGeometryChunkSource extends ChunkSource {\n immediateChunkUpdates = true;\n chunks: Map;\n\n constructor(\n chunkManager: Borrowed,\n public parent: Borrowed,\n public relationshipIndex: number,\n ) {\n super(chunkManager, {});\n }\n\n addChunk(key: string, chunk: AnnotationSubsetGeometryChunk) {\n super.addChunk(key, chunk);\n // TODO: process local deletions\n }\n\n getChunk(x: any): AnnotationSubsetGeometryChunk {\n return new AnnotationSubsetGeometryChunk(this, x);\n }\n}\n\nexport class AnnotationMetadataChunk extends Chunk {\n annotation: Annotation | null;\n constructor(source: Borrowed, x: any) {\n super(source);\n this.annotation = fixAnnotationAfterStructuredCloning(x.annotation);\n }\n}\n\n@registerSharedObjectOwner(ANNOTATION_METADATA_CHUNK_SOURCE_RPC_ID)\nexport class AnnotationMetadataChunkSource extends ChunkSource {\n chunks: Map;\n constructor(\n chunkManager: Borrowed,\n public parent: Borrowed,\n ) {\n super(chunkManager);\n }\n getChunk(x: any): AnnotationMetadataChunk {\n return new AnnotationMetadataChunk(this, x);\n }\n addChunk(key: string, chunk: AnnotationMetadataChunk) {\n super.addChunk(key, chunk);\n const { references } = this.parent;\n const reference = references.get(key);\n if (reference !== undefined) {\n reference.value = chunk.annotation;\n reference.changed.dispatch();\n }\n }\n deleteChunk(key: string) {\n const { references } = this.parent;\n const reference = references.get(key);\n if (reference !== undefined) {\n reference.value = undefined;\n reference.changed.dispatch();\n }\n }\n}\n\nfunction copyOtherAnnotations(\n serializedAnnotations: SerializedAnnotations,\n propertySerializers: AnnotationPropertySerializer[],\n excludedType: AnnotationType,\n excludedTypeAdjustment: number,\n): Uint8Array {\n const newData = new Uint8Array(\n serializedAnnotations.data.length + excludedTypeAdjustment,\n );\n // Copy all other annotation types\n for (const otherType of annotationTypes) {\n if (otherType === excludedType) continue;\n const otherTypeOffset = serializedAnnotations.typeToOffset![otherType];\n let newTypeOffset = otherTypeOffset;\n if (otherType > excludedType) {\n newTypeOffset += excludedTypeAdjustment;\n serializedAnnotations.typeToOffset![otherType] = newTypeOffset;\n }\n newData.set(\n serializedAnnotations.data.subarray(\n otherTypeOffset,\n otherTypeOffset +\n serializedAnnotations.typeToIds[otherType].length *\n propertySerializers[otherType].serializedBytes,\n ),\n newTypeOffset,\n );\n }\n return newData;\n}\n\nfunction copyAnnotationSlice(\n serializedAnnotations: SerializedAnnotations,\n propertySerializers: AnnotationPropertySerializer[],\n type: AnnotationType,\n dest: Uint8Array,\n sourceBeginIndex: number,\n sourceEndIndex: number,\n destBeginIndex: number,\n destCount: number,\n) {\n const typeOffset = serializedAnnotations.typeToOffset[type];\n let sourceGroupOffset = typeOffset;\n let destGroupOffset = typeOffset;\n const { propertyGroupBytes } = propertySerializers[type];\n const numGroups = propertyGroupBytes.length;\n const count = serializedAnnotations.typeToIds[type].length;\n for (let groupIndex = 0; groupIndex < numGroups; ++groupIndex) {\n const groupBytes = propertyGroupBytes[groupIndex];\n dest.set(\n serializedAnnotations.data.subarray(\n sourceGroupOffset + sourceBeginIndex * groupBytes,\n sourceGroupOffset + sourceEndIndex * groupBytes,\n ),\n destGroupOffset + destBeginIndex * groupBytes,\n );\n sourceGroupOffset += groupBytes * count;\n destGroupOffset += groupBytes * destCount;\n }\n}\n\nexport function updateAnnotation(\n chunk: AnnotationGeometryData,\n annotation: Annotation,\n propertySerializers: AnnotationPropertySerializer[],\n) {\n // Find insertion point.\n const type = annotation.type;\n const { rank } = propertySerializers[type];\n const { serializedAnnotations } = chunk;\n const ids = serializedAnnotations.typeToIds[type];\n const idMap = serializedAnnotations.typeToIdMaps[type];\n const handler = annotationTypeHandlers[type];\n const numBytes = propertySerializers[type].serializedBytes;\n let index = idMap.get(annotation.id);\n if (index === undefined) {\n // Doesn't already exist.\n index = idMap.size;\n idMap.set(annotation.id, index);\n const newData = copyOtherAnnotations(\n serializedAnnotations,\n propertySerializers,\n type,\n numBytes,\n );\n copyAnnotationSlice(\n serializedAnnotations,\n propertySerializers,\n type,\n newData,\n /*sourceBeginIndex=*/ 0,\n /*sourceEndIndex=*/ index,\n /*destBeginIndex=*/ 0,\n /*destCount=*/ index + 1,\n );\n ids.push(annotation.id);\n serializedAnnotations.data = newData;\n }\n const bufferOffset = serializedAnnotations.typeToOffset![type];\n const dv = new DataView(\n serializedAnnotations.data.buffer,\n serializedAnnotations.data.byteOffset,\n serializedAnnotations.data.byteLength,\n );\n const isLittleEndian = ENDIANNESS === Endianness.LITTLE;\n const propertySerializer = propertySerializers[type];\n handler.serialize(\n dv,\n bufferOffset + propertySerializer.propertyGroupBytes[0] * index,\n isLittleEndian,\n rank,\n annotation,\n );\n propertySerializer.serialize(\n dv,\n bufferOffset,\n index,\n ids.length,\n isLittleEndian,\n annotation.properties,\n );\n chunk.bufferValid = false;\n}\n\nexport function deleteAnnotation(\n chunk: AnnotationGeometryData,\n type: AnnotationType,\n id: AnnotationId,\n propertySerializers: AnnotationPropertySerializer[],\n): boolean {\n const { serializedAnnotations } = chunk;\n const idMap = serializedAnnotations.typeToIdMaps[type];\n const index = idMap.get(id);\n if (index === undefined) {\n return false;\n }\n const ids = serializedAnnotations.typeToIds[type];\n const numBytes = propertySerializers[type].serializedBytes;\n const newData = copyOtherAnnotations(\n serializedAnnotations,\n propertySerializers,\n type,\n -numBytes,\n );\n copyAnnotationSlice(\n serializedAnnotations,\n propertySerializers,\n type,\n newData,\n /*sourceBeginIndex=*/ 0,\n /*sourceEndIndex=*/ index,\n /*destBeginIndex=*/ 0,\n /*destCount=*/ ids.length - 1,\n );\n copyAnnotationSlice(\n serializedAnnotations,\n propertySerializers,\n type,\n newData,\n /*sourceBeginIndex=*/ index + 1,\n /*sourceEndIndex=*/ ids.length,\n /*destBeginIndex=*/ index,\n /*destCount=*/ ids.length - 1,\n );\n ids.splice(index, 1);\n idMap.delete(id);\n for (let i = index, count = ids.length; i < count; ++i) {\n idMap.set(ids[i], i);\n }\n serializedAnnotations.data = newData;\n chunk.bufferValid = false;\n return true;\n}\n\ninterface LocalUpdateUndoState {\n /**\n * If commitInProgress === undefined, this must be undefined. Otherwise, it specifies a commit\n * that has been requested and which will be initiated as soon as the in-progress request\n * completes.\n */\n pendingCommit: Annotation | null | undefined;\n\n reference: Owned;\n\n /**\n * The state of the annotation prior to any local modifications.\n */\n existingAnnotation: Annotation | undefined;\n\n /**\n * If not undefined, a commit has been sent to the backend, and we are waiting for the result.\n */\n commitInProgress: Annotation | null | undefined;\n type: AnnotationType;\n}\n\nexport function makeTemporaryChunk() {\n const typeToIds: string[][] = [];\n const typeToOffset: number[] = [];\n const typeToIdMaps: Map[] = [];\n for (const annotationType of annotationTypes) {\n typeToIds[annotationType] = [];\n typeToOffset[annotationType] = 0;\n typeToIdMaps[annotationType] = new Map();\n }\n return new AnnotationGeometryChunk(\n (undefined),\n {\n data: new Uint8Array(0),\n numPickIds: 0,\n typeToOffset,\n typeToIds,\n typeToIdMaps,\n },\n );\n}\n\nexport class MultiscaleAnnotationSource\n extends SharedObject\n implements\n MultiscaleSliceViewChunkSource,\n AnnotationSourceSignals\n{\n OPTIONS: object;\n key: any;\n metadataChunkSource = this.registerDisposer(\n new AnnotationMetadataChunkSource(this.chunkManager, this),\n );\n segmentFilteredSources: Owned[];\n spatiallyIndexedSources = new Set>();\n rank: number;\n readonly relationships: readonly string[];\n readonly properties: WatchableValue<\n readonly Readonly[]\n >;\n readonly annotationPropertySerializers: AnnotationPropertySerializer[];\n constructor(\n public chunkManager: Borrowed,\n options: {\n rank: number;\n relationships: readonly string[];\n properties: Readonly[];\n },\n ) {\n super();\n this.rank = options.rank;\n this.properties = new WatchableValue(options.properties);\n this.annotationPropertySerializers = makeAnnotationPropertySerializers(\n this.rank,\n this.properties.value,\n );\n const segmentFilteredSources: Owned[] =\n (this.segmentFilteredSources = []);\n const { relationships } = options;\n this.relationships = relationships;\n for (let i = 0, count = relationships.length; i < count; ++i) {\n segmentFilteredSources.push(\n this.registerDisposer(\n new AnnotationSubsetGeometryChunkSource(chunkManager, this, i),\n ),\n );\n }\n }\n\n hasNonSerializedProperties() {\n return this.relationships.length > 0;\n }\n\n getSources(\n _options: SliceViewSourceOptions,\n ): SliceViewSingleResolutionSource[][] {\n throw new Error(\"not implemented\");\n }\n\n temporary = makeTemporaryChunk();\n\n references = new Map>();\n\n localUpdates = new Map();\n\n initializeCounterpart(rpc: RPC, options: any) {\n this.metadataChunkSource.initializeCounterpart(rpc, {});\n for (const source of this.segmentFilteredSources) {\n source.initializeCounterpart(rpc, {});\n }\n options.segmentFilteredSource = this.segmentFilteredSources.map((x) =>\n x.addCounterpartRef(),\n );\n options.metadataChunkSource = this.metadataChunkSource.addCounterpartRef();\n options.chunkManager = this.chunkManager.rpcId;\n super.initializeCounterpart(rpc, options);\n }\n\n add(annotation: Annotation, commit = true): AnnotationReference {\n annotation.id = makeAnnotationId();\n const reference = new AnnotationReference(annotation.id);\n reference.value = annotation;\n this.references.set(reference.id, reference);\n reference.registerDisposer(() => {\n this.references.delete(reference.id);\n });\n this.applyLocalUpdate(\n reference,\n /*existing=*/ false,\n /*commit=*/ commit,\n /*newAnnotation=*/ annotation,\n );\n return reference;\n }\n\n private applyLocalUpdate(\n reference: Borrowed,\n existing: boolean,\n commit: boolean,\n newAnnotation: Annotation | null,\n ): void {\n const { localUpdates } = this;\n const { id } = reference;\n let localUpdate = this.localUpdates.get(id);\n const annotation = reference.value;\n if (annotation == null) {\n throw new Error(\"Cannot create local update from null annotation\");\n }\n if (localUpdate === undefined) {\n localUpdate = {\n type: annotation.type,\n reference: reference.addRef(),\n existingAnnotation: existing ? annotation : undefined,\n pendingCommit: undefined,\n commitInProgress: undefined,\n };\n localUpdates.set(id, localUpdate);\n this.forEachPossibleChunk(annotation, (chunk) => {\n const { data } = chunk;\n if (data === undefined) return;\n const annotationType = annotation.type;\n deleteAnnotation(\n data,\n annotationType,\n id,\n this.annotationPropertySerializers,\n );\n });\n if (newAnnotation !== null) {\n // Add to temporary chunk.\n updateAnnotation(\n this.temporary.data!,\n newAnnotation,\n this.annotationPropertySerializers,\n );\n }\n } else {\n if (newAnnotation === null) {\n // Annotation has a local update already, so we need to delete it from the temporary chunk.\n deleteAnnotation(\n this.temporary.data!,\n annotation.type,\n annotation.id,\n this.annotationPropertySerializers,\n );\n } else {\n // Modify existing entry in temporary chunk.\n updateAnnotation(\n this.temporary.data!,\n newAnnotation,\n this.annotationPropertySerializers,\n );\n }\n reference.value = newAnnotation;\n }\n if (commit) {\n if (localUpdate.commitInProgress !== undefined) {\n localUpdate.pendingCommit = newAnnotation;\n } else {\n if (\n newAnnotation === null &&\n localUpdate.existingAnnotation === undefined\n ) {\n // Local update, which we would now like to delete, has never been committed.\n // Therefore we can just delete it locally.\n localUpdates.delete(id);\n localUpdate.reference.dispose();\n return;\n }\n this.sendCommitRequest(localUpdate, newAnnotation);\n }\n }\n this.notifyChanged(reference.id, newAnnotation || undefined);\n }\n\n private sendCommitRequest(\n localUpdate: LocalUpdateUndoState,\n newAnnotation: Annotation | null,\n ) {\n this.updateCommitsInProgress(1);\n localUpdate.commitInProgress = newAnnotation;\n this.rpc!.invoke(ANNOTATION_COMMIT_UPDATE_RPC_ID, {\n id: this.rpcId,\n annotationId: localUpdate.existingAnnotation && localUpdate.reference.id,\n newAnnotation,\n });\n }\n\n delete(reference: Borrowed) {\n this.applyLocalUpdate(\n reference,\n /*existing=*/ true,\n /*commit=*/ true,\n /*newAnnotation=*/ null,\n );\n }\n\n update(reference: AnnotationReference, newAnnotation: Annotation) {\n this.applyLocalUpdate(\n reference,\n /*existing=*/ true,\n /*commit=*/ false,\n /*newAnnotation=*/ newAnnotation,\n );\n }\n\n private notifyChanged(id: AnnotationId, annotation: Annotation | undefined) {\n const reference = this.references.get(id);\n const chunk = this.metadataChunkSource.chunks.get(id);\n if (chunk !== undefined) {\n chunk.annotation = annotation || null;\n }\n if (reference !== undefined) {\n reference.value = annotation || null;\n reference.changed.dispatch();\n }\n this.chunkManager.chunkQueueManager.visibleChunksChanged.dispatch();\n }\n\n /**\n * Must be called after `add` or `update` to commit the result.\n */\n commit(reference: Borrowed) {\n this.applyLocalUpdate(\n reference,\n /*existing=*/ true,\n /*commit=*/ true,\n reference.value!,\n );\n }\n\n getReference(id: AnnotationId): Owned {\n let existing = this.references.get(id);\n if (existing !== undefined) {\n return existing.addRef();\n }\n existing = new AnnotationReference(id);\n this.references.set(id, existing);\n this.rpc!.invoke(ANNOTATION_REFERENCE_ADD_RPC_ID, {\n id: this.rpcId,\n annotation: id,\n });\n existing.registerDisposer(() => {\n this.references.delete(id);\n this.rpc!.invoke(ANNOTATION_REFERENCE_DELETE_RPC_ID, {\n id: this.rpcId,\n annotation: id,\n });\n });\n const chunk = this.metadataChunkSource.chunks.get(id);\n if (chunk !== undefined) {\n existing.value = chunk.annotation;\n }\n return existing;\n }\n\n private forEachPossibleChunk(\n annotation: Annotation,\n callback: (\n chunk: AnnotationGeometryChunk | AnnotationSubsetGeometryChunk,\n ) => void,\n ) {\n annotation;\n const { relatedSegments } = annotation;\n if (relatedSegments !== undefined) {\n const numRelationships = relatedSegments.length;\n const { segmentFilteredSources } = this;\n for (let i = 0; i < numRelationships; ++i) {\n const segments = relatedSegments[i];\n if (segments === undefined) return;\n const source = segmentFilteredSources[i];\n for (const segment of segments) {\n const chunk = source.chunks.get(getObjectKey(segment));\n if (chunk === undefined) {\n continue;\n }\n callback(chunk);\n }\n }\n }\n const { rank } = this;\n const tempLower = new Float32Array(rank);\n const tempUpper = new Float32Array(rank);\n const tempChunk = new Float32Array(rank);\n for (const source of this.spatiallyIndexedSources) {\n switch (annotation.type) {\n case AnnotationType.POINT:\n matrix.transformPoint(\n tempLower,\n source.multiscaleToChunkTransform,\n rank + 1,\n annotation.point,\n rank,\n );\n tempUpper.set(tempLower);\n break;\n case AnnotationType.LINE:\n case AnnotationType.AXIS_ALIGNED_BOUNDING_BOX:\n matrix.transformPoint(\n tempLower,\n source.multiscaleToChunkTransform,\n rank + 1,\n annotation.pointA,\n rank,\n );\n matrix.transformPoint(\n tempUpper,\n source.multiscaleToChunkTransform,\n rank + 1,\n annotation.pointB,\n rank,\n );\n break;\n case AnnotationType.ELLIPSOID:\n matrix.transformPoint(\n tempLower,\n source.multiscaleToChunkTransform,\n rank + 1,\n annotation.center,\n rank,\n );\n matrix.transformVector(\n tempUpper,\n source.multiscaleToChunkTransform,\n rank + 1,\n annotation.radii,\n rank,\n );\n for (let i = 0; i < rank; ++i) {\n const c = tempLower[i];\n const r = tempUpper[i];\n tempLower[i] = c - r;\n tempUpper[i] = c + r;\n }\n break;\n }\n let totalChunks = 1;\n for (let i = 0; i < rank; ++i) {\n const a = tempLower[i];\n const b = tempUpper[i];\n const lower = Math.min(a, b);\n const upper = Math.max(a, b);\n // In the case that the point lies directly on a boundary, ensure it is included in both\n // chunks, since we don't know how the datasource handles this case.\n tempLower[i] = Math.ceil(lower - 1);\n tempUpper[i] = Math.floor(upper + 1);\n totalChunks *= tempUpper[i] - tempLower[i];\n }\n const { chunks } = source;\n for (let chunkIndex = 0; chunkIndex < totalChunks; ++chunkIndex) {\n let remainder = chunkIndex;\n for (let i = 0; i < rank; ++i) {\n const lower = tempLower[i];\n const upper = tempUpper[i];\n const size = upper - lower;\n const x = (tempChunk[i] = remainder % size);\n remainder = (remainder - x) / size;\n }\n const chunk = chunks.get(tempChunk.join());\n if (chunk !== undefined) {\n callback(chunk);\n }\n }\n }\n }\n\n static encodeOptions(_options: object): { [key: string]: any } {\n return {};\n }\n\n handleSuccessfulUpdate(id: AnnotationId, newAnnotation: Annotation | null) {\n const localUpdate = this.localUpdates.get(id);\n if (\n localUpdate === undefined ||\n localUpdate.commitInProgress === undefined\n ) {\n throw new Error(\"Received invalid successful update notification\");\n }\n this.updateCommitsInProgress(-1);\n if (\n newAnnotation !== null &&\n localUpdate.reference.id !== newAnnotation.id\n ) {\n if (localUpdate.commitInProgress === null) {\n throw new Error(\"Received invalid successful update notification\");\n }\n localUpdate.reference.id = newAnnotation.id;\n this.references.delete(id);\n this.references.set(newAnnotation.id, localUpdate.reference);\n this.localUpdates.delete(id);\n this.localUpdates.set(newAnnotation.id, localUpdate);\n if (localUpdate.reference.value !== null) {\n localUpdate.reference.value!.id = newAnnotation.id;\n deleteAnnotation(\n this.temporary.data!,\n localUpdate.type,\n id,\n this.annotationPropertySerializers,\n );\n updateAnnotation(\n this.temporary.data!,\n localUpdate.reference.value!,\n this.annotationPropertySerializers,\n );\n }\n localUpdate.reference.changed.dispatch();\n }\n localUpdate.existingAnnotation = newAnnotation || undefined;\n localUpdate.commitInProgress = undefined;\n let { pendingCommit } = localUpdate;\n localUpdate.pendingCommit = undefined;\n if (newAnnotation === null) {\n pendingCommit = undefined;\n }\n if (pendingCommit !== undefined) {\n if (pendingCommit !== null) {\n pendingCommit.id = newAnnotation!.id;\n }\n this.sendCommitRequest(localUpdate, pendingCommit);\n } else {\n this.revertLocalUpdate(localUpdate);\n }\n }\n\n private numCommitsInProgress = 0;\n\n private commitStatus: StatusMessage | undefined;\n\n disposed() {\n const { commitStatus } = this;\n if (commitStatus !== undefined) {\n commitStatus.dispose();\n }\n }\n\n private updateCommitsInProgress(amount: number) {\n this.numCommitsInProgress += amount;\n if (this.numCommitsInProgress === 0) {\n if (this.commitStatus !== undefined) {\n this.commitStatus.dispose();\n this.commitStatus = undefined;\n }\n } else if (this.commitStatus === undefined) {\n const status = (this.commitStatus = new StatusMessage(/*delay=*/ true));\n status.setText(\"Commiting annotations\");\n }\n }\n\n handleFailedUpdate(id: AnnotationId, message: string) {\n const localUpdate = this.localUpdates.get(id);\n if (\n localUpdate === undefined ||\n localUpdate.commitInProgress === undefined\n ) {\n throw new Error(\"Received invalid update notification\");\n }\n const status = new StatusMessage();\n status.setErrorMessage(`Error commiting annotation update: ${message}`);\n this.revertLocalUpdate(localUpdate);\n this.updateCommitsInProgress(-1);\n }\n\n private revertLocalUpdate(localUpdate: LocalUpdateUndoState) {\n deleteAnnotation(\n this.temporary.data!,\n localUpdate.type,\n localUpdate.reference.id,\n this.annotationPropertySerializers,\n );\n const { existingAnnotation } = localUpdate;\n if (existingAnnotation !== undefined) {\n this.forEachPossibleChunk(existingAnnotation, (chunk) => {\n const { data } = chunk;\n if (data === undefined) return;\n updateAnnotation(\n data,\n existingAnnotation,\n this.annotationPropertySerializers,\n );\n });\n }\n const { reference } = localUpdate;\n const { id } = reference;\n\n reference.value = existingAnnotation || null;\n reference.changed.dispatch();\n\n reference.dispose();\n\n this.localUpdates.delete(id);\n }\n\n // FIXME\n changed = new NullarySignal();\n *[Symbol.iterator](): Iterator {}\n readonly = false;\n childAdded: Signal<(annotation: Annotation) => void>;\n childUpdated: Signal<(annotation: Annotation) => void>;\n childCommitted: Signal<(annotationId: string) => void>;\n childDeleted: Signal<(annotationId: string) => void>;\n}\n\nregisterRPC(ANNOTATION_COMMIT_UPDATE_RESULT_RPC_ID, function (x) {\n const source = this.get(x.id);\n const annotationId: AnnotationId = x.annotationId;\n const error: string | undefined = x.error;\n if (error !== undefined) {\n source.handleFailedUpdate(annotationId, error);\n } else {\n const newAnnotation: Annotation | null =\n fixAnnotationAfterStructuredCloning(x.newAnnotation);\n source.handleSuccessfulUpdate(annotationId, newAnnotation);\n }\n});\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { defaultStringCompare } from \"#src/util/string.js\";\n\nexport interface Completion {\n value: string;\n}\n\nexport interface CompletionWithDescription extends Completion {\n description?: string;\n}\n\nexport interface BasicCompletionResult {\n completions: C[];\n offset: number;\n}\n\nexport const emptyCompletionResult = {\n offset: 0,\n completions: [],\n};\n\nexport function applyCompletionOffset(\n offset: number,\n completionResult: T,\n) {\n completionResult.offset += offset;\n return completionResult;\n}\n\nexport function getPrefixMatches(prefix: string, options: Iterable) {\n const result: Completion[] = [];\n for (const option of options) {\n if (option.startsWith(prefix)) {\n result.push({ value: option });\n }\n }\n result.sort((a, b) => defaultStringCompare(a.value, b.value));\n return result;\n}\n\nexport function getPrefixMatchesWithDescriptions(\n prefix: string,\n options: Iterable,\n getValue: (x: T) => string,\n getDescription: (x: T) => string | undefined,\n) {\n const result: CompletionWithDescription[] = [];\n for (const option of options) {\n const key = getValue(option);\n if (key.startsWith(prefix)) {\n result.push({ value: key, description: getDescription(option) });\n }\n }\n result.sort((a, b) => defaultStringCompare(a.value, b.value));\n return result;\n}\n\nexport async function completeQueryStringParameters(\n queryString: string,\n keyCompleter: (value: string) => Promise>,\n valueCompleter: (\n key: string,\n value: string,\n ) => Promise>,\n): Promise> {\n if (queryString.startsWith(\"{\")) return emptyCompletionResult;\n const m = queryString.match(/^(?:(.*)[&;])?([^&;]*)$/);\n const part = m![2];\n const offset = queryString.length - part.length;\n const equalsIndex = part.indexOf(\"=\");\n if (equalsIndex === -1) {\n const completions = await keyCompleter(part);\n return {\n offset: completions.offset + offset,\n completions: completions.completions.map((x) => ({\n ...x,\n value: `${x.value}=`,\n })),\n };\n }\n return applyCompletionOffset(\n offset + equalsIndex + 1,\n await valueCompleter(\n part.substring(0, equalsIndex),\n part.substring(equalsIndex + 1),\n ),\n );\n}\n\nexport interface QueryStringCompletionTableEntry<\n C extends Completion = Completion,\n> {\n readonly key: C;\n readonly values: readonly C[];\n}\n\nexport type QueryStringCompletionTable =\n readonly QueryStringCompletionTableEntry[];\n\nexport async function completeQueryStringParametersFromTable<\n C extends Completion,\n>(queryString: string, table: QueryStringCompletionTable) {\n return completeQueryStringParameters(\n queryString,\n async (key) => {\n const results: C[] = [];\n for (const entry of table) {\n const keyEntry = entry.key;\n if (keyEntry.value.startsWith(key)) results.push(keyEntry);\n }\n return { offset: 0, completions: results };\n },\n async (key, value) => {\n for (const entry of table) {\n if (entry.key.value !== key) continue;\n return {\n offset: 0,\n completions: entry.values.filter((x) => x.value.startsWith(value)),\n };\n }\n return emptyCompletionResult;\n },\n );\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { MultiscaleAnnotationSource } from \"#src/annotation/frontend_source.js\";\nimport type { AnnotationSource } from \"#src/annotation/index.js\";\nimport type { ChunkManager } from \"#src/chunk_manager/frontend.js\";\nimport type {\n CoordinateSpace,\n CoordinateSpaceTransform,\n CoordinateTransformSpecification,\n} from \"#src/coordinate_transform.js\";\nimport {\n emptyValidCoordinateSpace,\n makeCoordinateSpace,\n makeIdentityTransform,\n} from \"#src/coordinate_transform.js\";\nimport type { CredentialsManager } from \"#src/credentials_provider/index.js\";\nimport type { MeshSource, MultiscaleMeshSource } from \"#src/mesh/frontend.js\";\nimport type { SegmentPropertyMap } from \"#src/segmentation_display_state/property_map.js\";\nimport type { SegmentationGraphSource } from \"#src/segmentation_graph/source.js\";\nimport type { SingleMeshSource } from \"#src/single_mesh/frontend.js\";\nimport type { SkeletonSource } from \"#src/skeleton/frontend.js\";\nimport type { MultiscaleVolumeChunkSource } from \"#src/sliceview/volume/frontend.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport type { CancellationToken } from \"#src/util/cancellation.js\";\nimport { uncancelableToken } from \"#src/util/cancellation.js\";\nimport type {\n BasicCompletionResult,\n CompletionWithDescription,\n} from \"#src/util/completion.js\";\nimport {\n applyCompletionOffset,\n getPrefixMatchesWithDescriptions,\n} from \"#src/util/completion.js\";\nimport type { Owned } from \"#src/util/disposable.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { createIdentity } from \"#src/util/matrix.js\";\nimport type { Trackable } from \"#src/util/trackable.js\";\n\nexport type CompletionResult = BasicCompletionResult;\n\nexport class RedirectError extends Error {\n constructor(public redirectTarget: string) {\n super(`Redirected to: ${redirectTarget}`);\n }\n}\n\n/**\n * Returns the length of the prefix of path that corresponds to the \"group\", according to the\n * specified separator.\n *\n * If the separator is not specified, gueses whether it is '/' or ':'.\n */\nexport function findSourceGroupBasedOnSeparator(\n path: string,\n separator?: string,\n) {\n if (separator === undefined) {\n // Try to guess whether '/' or ':' is the separator.\n if (path.indexOf(\"/\") === -1) {\n separator = \":\";\n } else {\n separator = \"/\";\n }\n }\n const index = path.lastIndexOf(separator);\n if (index === -1) {\n return 0;\n }\n return index + 1;\n}\n\n/**\n * Returns the last \"component\" of path, according to the specified separator.\n * If the separator is not specified, gueses whether it is '/' or ':'.\n */\nexport function suggestLayerNameBasedOnSeparator(\n path: string,\n separator?: string,\n) {\n const groupIndex = findSourceGroupBasedOnSeparator(path, separator);\n return path.substring(groupIndex);\n}\n\nexport interface GetDataSourceOptionsBase {\n chunkManager: ChunkManager;\n cancellationToken?: CancellationToken;\n url: string;\n transform: CoordinateTransformSpecification | undefined;\n globalCoordinateSpace: WatchableValueInterface;\n state?: any;\n}\n\nexport interface GetDataSourceOptions extends GetDataSourceOptionsBase {\n registry: DataSourceProviderRegistry;\n providerUrl: string;\n cancellationToken: CancellationToken;\n providerProtocol: string;\n credentialsManager: CredentialsManager;\n}\n\nexport interface ConvertLegacyUrlOptionsBase {\n url: string;\n type: \"mesh\" | \"skeletons\" | \"single_mesh\";\n}\n\nexport interface ConvertLegacyUrlOptions extends ConvertLegacyUrlOptionsBase {\n registry: DataSourceProviderRegistry;\n providerUrl: string;\n providerProtocol: string;\n}\n\nexport interface NormalizeUrlOptionsBase {\n url: string;\n}\n\nexport interface NormalizeUrlOptions extends NormalizeUrlOptionsBase {\n registry: DataSourceProviderRegistry;\n providerUrl: string;\n providerProtocol: string;\n}\n\nexport enum LocalDataSource {\n annotations = 0,\n equivalences = 1,\n}\n\nexport interface DataSubsource {\n volume?: MultiscaleVolumeChunkSource;\n mesh?: MeshSource | MultiscaleMeshSource | SkeletonSource;\n annotation?: MultiscaleAnnotationSource;\n staticAnnotations?: AnnotationSource;\n local?: LocalDataSource;\n singleMesh?: SingleMeshSource;\n segmentPropertyMap?: SegmentPropertyMap;\n segmentationGraph?: SegmentationGraphSource;\n}\n\nexport interface CompleteUrlOptionsBase {\n url: string;\n cancellationToken?: CancellationToken;\n chunkManager: ChunkManager;\n}\n\nexport interface CompleteUrlOptions extends CompleteUrlOptionsBase {\n registry: DataSourceProviderRegistry;\n providerUrl: string;\n cancellationToken: CancellationToken;\n credentialsManager: CredentialsManager;\n}\n\nexport interface DataSubsourceEntry {\n /**\n * Unique identifier (within the group) for this subsource. Stored in the JSON state\n * representation to indicate which subsources are enabled. The empty string `\"\"` should be used\n * for the first/primary subsource.\n */\n id: string;\n\n subsource: DataSubsource;\n\n /**\n * Homoegeneous transformation from the subsource to the model subspace corresponding to\n * `modelSubspceDimensionIndices`. The rank is equal to the length of\n * `modelSubspaceDimensionIndices`. If this is greater than the subsource rank, the subsource\n * coordinate space is implicitly padded at the end with additional dummy dimensions with a range\n * of `[0, 1]`. If unspecified, defaults to the identity transform.\n */\n subsourceToModelSubspaceTransform?: Float32Array;\n\n /**\n * Specifies the model dimensions corresponding to this subsource. If unspecified, defaults to\n * `[0, ..., modelSpace.rank)`.\n */\n modelSubspaceDimensionIndices?: number[];\n\n /**\n * Specifies whether this associated data source is enabled by default.\n */\n default: boolean;\n}\n\nexport interface DataSource {\n subsources: DataSubsourceEntry[];\n modelTransform: CoordinateSpaceTransform;\n canChangeModelSpaceRank?: boolean;\n state?: Trackable;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging\nexport interface DataSourceProvider {\n /**\n * Returns a suggested layer name for the given volume source.\n */\n suggestLayerName?(path: string): string;\n\n /**\n * Returns the length of the prefix of path that is its 'group'. This is used for suggesting a\n * default URL for adding a new layer.\n */\n findSourceGroup?(path: string): number;\n}\n\nexport interface DataSubsourceSpecification {\n enabled?: boolean;\n}\n\nexport interface DataSourceSpecification {\n url: string;\n transform: CoordinateTransformSpecification | undefined;\n enableDefaultSubsources: boolean;\n subsources: Map;\n state?: any;\n}\n\nexport function makeEmptyDataSourceSpecification(): DataSourceSpecification {\n return {\n url: \"\",\n transform: undefined,\n enableDefaultSubsources: true,\n subsources: new Map(),\n };\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging\nexport abstract class DataSourceProvider extends RefCounted {\n abstract description?: string;\n\n abstract get(options: GetDataSourceOptions): Promise;\n\n normalizeUrl(options: NormalizeUrlOptions): string {\n return options.url;\n }\n\n convertLegacyUrl(options: ConvertLegacyUrlOptions): string {\n return options.url;\n }\n\n async completeUrl(options: CompleteUrlOptions): Promise {\n options;\n throw null;\n }\n}\n\nexport const localAnnotationsUrl = \"local://annotations\";\nexport const localEquivalencesUrl = \"local://equivalences\";\n\nclass LocalDataSourceProvider extends DataSourceProvider {\n get description() {\n return \"Local in-memory\";\n }\n\n async get(options: GetDataSourceOptions): Promise {\n switch (options.url) {\n case localAnnotationsUrl: {\n const { transform } = options;\n let modelTransform: CoordinateSpaceTransform;\n if (transform === undefined) {\n const baseSpace = options.globalCoordinateSpace.value;\n const { rank, names, scales, units } = baseSpace;\n const inputSpace = makeCoordinateSpace({\n rank,\n scales,\n units,\n names: names.map((_, i) => `${i}`),\n });\n const outputSpace = makeCoordinateSpace({\n rank,\n scales,\n units,\n names,\n });\n modelTransform = {\n rank,\n sourceRank: rank,\n inputSpace,\n outputSpace,\n transform: createIdentity(Float64Array, rank + 1),\n };\n } else {\n modelTransform = makeIdentityTransform(emptyValidCoordinateSpace);\n }\n return {\n modelTransform,\n canChangeModelSpaceRank: true,\n subsources: [\n {\n id: \"default\",\n default: true,\n subsource: {\n local: LocalDataSource.annotations,\n },\n },\n ],\n };\n }\n case localEquivalencesUrl: {\n return {\n modelTransform: makeIdentityTransform(emptyValidCoordinateSpace),\n canChangeModelSpaceRank: false,\n subsources: [\n {\n id: \"default\",\n default: true,\n subsource: {\n local: LocalDataSource.equivalences,\n },\n },\n ],\n };\n }\n }\n throw new Error(\"Invalid local data source URL\");\n }\n\n async completeUrl(options: CompleteUrlOptions) {\n return {\n offset: 0,\n completions: getPrefixMatchesWithDescriptions(\n options.providerUrl,\n [\n {\n value: \"annotations\",\n description: \"Annotations stored in the JSON state\",\n },\n {\n value: \"equivalences\",\n description:\n \"Segmentation equivalence graph stored in the JSON state\",\n },\n ],\n (x) => x.value,\n (x) => x.description,\n ),\n };\n }\n}\n\nconst protocolPattern = /^(?:([a-zA-Z][a-zA-Z0-9-+_]*):\\/\\/)?(.*)$/;\n\nexport class DataSourceProviderRegistry extends RefCounted {\n constructor(public credentialsManager: CredentialsManager) {\n super();\n }\n dataSources = new Map>([\n [\"local\", new LocalDataSourceProvider()],\n ]);\n\n register(name: string, dataSource: Owned) {\n this.dataSources.set(name, this.registerDisposer(dataSource));\n }\n\n getProvider(url: string): [DataSourceProvider, string, string] {\n const m = url.match(protocolPattern);\n if (m === null || m[1] === undefined) {\n throw new Error(\n `Data source URL must have the form \"://\".`,\n );\n }\n const [, providerProtocol, providerUrl] = m;\n const factory = this.dataSources.get(providerProtocol);\n if (factory === undefined) {\n throw new Error(\n `Unsupported data source: ${JSON.stringify(providerProtocol)}.`,\n );\n }\n return [factory, providerUrl, providerProtocol];\n }\n\n async get(options: GetDataSourceOptionsBase): Promise {\n const redirectLog = new Set();\n const { cancellationToken = uncancelableToken } = options;\n let url: string = options.url;\n while (true) {\n const [provider, providerUrl, providerProtocol] = this.getProvider(\n options.url,\n );\n redirectLog.add(options.url);\n try {\n return provider.get({\n ...options,\n url,\n providerProtocol,\n providerUrl,\n registry: this,\n cancellationToken,\n credentialsManager: this.credentialsManager,\n });\n } catch (e) {\n if (e instanceof RedirectError) {\n const redirect = e.redirectTarget;\n if (redirectLog.has(redirect)) {\n throw Error(\n `Layer source redirection contains loop: ${JSON.stringify(\n Array.from(redirectLog),\n )}`,\n );\n }\n if (redirectLog.size >= 10) {\n throw Error(\n `Too many layer source redirections: ${JSON.stringify(\n Array.from(redirectLog),\n )}`,\n );\n }\n url = redirect;\n continue;\n }\n throw e;\n }\n }\n }\n\n convertLegacyUrl(options: ConvertLegacyUrlOptionsBase): string {\n try {\n const [provider, providerUrl, providerProtocol] = this.getProvider(\n options.url,\n );\n return provider.convertLegacyUrl({\n ...options,\n providerUrl,\n providerProtocol,\n registry: this,\n });\n } catch {\n return options.url;\n }\n }\n\n normalizeUrl(options: NormalizeUrlOptionsBase): string {\n try {\n const [provider, providerUrl, providerProtocol] = this.getProvider(\n options.url,\n );\n return provider.normalizeUrl({\n ...options,\n providerUrl,\n providerProtocol,\n registry: this,\n });\n } catch {\n return options.url;\n }\n }\n\n async completeUrl(\n options: CompleteUrlOptionsBase,\n ): Promise {\n // Check if url matches a protocol. Note that protocolPattern always matches.\n const { url, cancellationToken = uncancelableToken } = options;\n const protocolMatch = url.match(protocolPattern)!;\n const protocol = protocolMatch[1];\n if (protocol === undefined) {\n return Promise.resolve({\n offset: 0,\n completions: getPrefixMatchesWithDescriptions(\n url,\n this.dataSources,\n ([name]) => `${name}://`,\n ([, factory]) => factory.description,\n ),\n });\n }\n const factory = this.dataSources.get(protocol);\n if (factory !== undefined) {\n const completions = await factory.completeUrl({\n registry: this,\n url,\n providerUrl: protocolMatch[2],\n chunkManager: options.chunkManager,\n cancellationToken,\n credentialsManager: this.credentialsManager,\n });\n return applyCompletionOffset(protocol.length + 3, completions);\n }\n throw null;\n }\n\n suggestLayerName(url: string) {\n let [dataSource, path] = this.getProvider(url);\n if (path.endsWith(\"/\")) {\n path = path.substring(0, path.length - 1);\n }\n const suggestor = dataSource.suggestLayerName;\n if (suggestor !== undefined) {\n return suggestor(path);\n }\n return suggestLayerNameBasedOnSeparator(path);\n }\n\n findSourceGroup(url: string) {\n const [dataSource, path, dataSourceName] = this.getProvider(url);\n const helper =\n dataSource.findSourceGroup || findSourceGroupBasedOnSeparator;\n return helper(path) + dataSourceName.length + 3;\n }\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type {\n CoordinateSpace,\n CoordinateTransformSpecification,\n} from \"#src/coordinate_transform.js\";\nimport {\n coordinateTransformSpecificationFromJson,\n coordinateTransformSpecificationToJson,\n makeCoordinateSpace,\n makeIdentityTransform,\n WatchableCoordinateSpaceTransform,\n} from \"#src/coordinate_transform.js\";\nimport type {\n DataSource,\n DataSourceSpecification,\n DataSubsourceEntry,\n DataSubsourceSpecification,\n} from \"#src/datasource/index.js\";\nimport { makeEmptyDataSourceSpecification } from \"#src/datasource/index.js\";\nimport type { UserLayer } from \"#src/layer/index.js\";\nimport { getWatchableRenderLayerTransform } from \"#src/render_coordinate_transform.js\";\nimport type { RenderLayer } from \"#src/renderlayer.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { arraysEqual } from \"#src/util/array.js\";\nimport { CancellationTokenSource } from \"#src/util/cancellation.js\";\nimport type { Borrowed, Owned } from \"#src/util/disposable.js\";\nimport { disposableOnce, RefCounted } from \"#src/util/disposable.js\";\nimport {\n verifyBoolean,\n verifyObject,\n verifyObjectAsMap,\n verifyObjectProperty,\n verifyOptionalObjectProperty,\n verifyString,\n} from \"#src/util/json.js\";\nimport * as matrix from \"#src/util/matrix.js\";\nimport { MessageList, MessageSeverity } from \"#src/util/message_list.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\n\nexport function parseDataSubsourceSpecificationFromJson(\n json: unknown,\n): DataSubsourceSpecification {\n if (typeof json === \"boolean\") {\n return { enabled: json };\n }\n verifyObject(json);\n return {\n enabled: verifyOptionalObjectProperty(json, \"enabled\", verifyBoolean),\n };\n}\n\nexport function layerDataSourceSpecificationFromJson(\n obj: unknown,\n legacyTransform: CoordinateTransformSpecification | undefined = undefined,\n): DataSourceSpecification {\n if (typeof obj === \"string\") {\n return {\n url: obj,\n transform: legacyTransform,\n enableDefaultSubsources: true,\n subsources: new Map(),\n };\n }\n verifyObject(obj);\n return {\n url: verifyObjectProperty(obj, \"url\", verifyString),\n transform:\n verifyObjectProperty(\n obj,\n \"transform\",\n coordinateTransformSpecificationFromJson,\n ) || legacyTransform,\n enableDefaultSubsources: verifyOptionalObjectProperty(\n obj,\n \"enableDefaultSubsources\",\n verifyBoolean,\n true,\n ),\n subsources: verifyOptionalObjectProperty(\n obj,\n \"subsources\",\n (subsourcesObj) =>\n verifyObjectAsMap(\n subsourcesObj,\n parseDataSubsourceSpecificationFromJson,\n ),\n new Map(),\n ),\n state: verifyOptionalObjectProperty(obj, \"state\", verifyObject),\n };\n}\n\nfunction dataSubsourceSpecificationToJson(spec: DataSubsourceSpecification) {\n return spec.enabled;\n}\n\nexport function layerDataSourceSpecificationToJson(\n spec: DataSourceSpecification,\n) {\n const transform = coordinateTransformSpecificationToJson(spec.transform);\n const subsourcesJson: any = {};\n let emptySubsources = true;\n for (const [id, subsource] of spec.subsources) {\n const j = dataSubsourceSpecificationToJson(subsource);\n if (j !== undefined) {\n subsourcesJson[id] = j;\n emptySubsources = false;\n }\n }\n if (\n transform === undefined &&\n emptySubsources &&\n spec.enableDefaultSubsources === true &&\n spec.state === undefined\n ) {\n return spec.url;\n }\n return {\n url: spec.url,\n transform,\n subsources: emptySubsources ? undefined : subsourcesJson,\n enableDefaultSubsources:\n spec.enableDefaultSubsources === true ? undefined : false,\n state: spec.state,\n };\n}\n\nexport class LoadedDataSubsource {\n subsourceToModelSubspaceTransform: Float32Array;\n modelSubspaceDimensionIndices: number[];\n enabled: boolean;\n activated: RefCounted | undefined = undefined;\n guardValues: any[] = [];\n messages = new MessageList();\n isActiveChanged = new NullarySignal();\n constructor(\n public loadedDataSource: LoadedLayerDataSource,\n public subsourceEntry: DataSubsourceEntry,\n public subsourceSpec: DataSubsourceSpecification | undefined,\n public subsourceIndex: number,\n enableDefaultSubsources: boolean,\n ) {\n let enabled: boolean;\n if (subsourceSpec === undefined || subsourceSpec.enabled === undefined) {\n enabled = subsourceEntry.default && enableDefaultSubsources;\n } else {\n enabled = subsourceSpec.enabled;\n }\n const modelRank = loadedDataSource.dataSource.modelTransform.sourceRank;\n let { modelSubspaceDimensionIndices } = subsourceEntry;\n if (modelSubspaceDimensionIndices === undefined) {\n modelSubspaceDimensionIndices = new Array(modelRank);\n for (let i = 0; i < modelRank; ++i) {\n modelSubspaceDimensionIndices[i] = i;\n }\n }\n const {\n subsourceToModelSubspaceTransform = matrix.createIdentity(\n Float32Array,\n modelSubspaceDimensionIndices.length + 1,\n ),\n } = subsourceEntry;\n this.enabled = enabled;\n this.subsourceToModelSubspaceTransform = subsourceToModelSubspaceTransform;\n this.modelSubspaceDimensionIndices = modelSubspaceDimensionIndices;\n this.isActiveChanged.add(\n loadedDataSource.activatedSubsourcesChanged.dispatch,\n );\n }\n\n activate(callback: (refCounted: RefCounted) => void, ...guardValues: any[]) {\n this.messages.clearMessages();\n if (this.activated !== undefined) {\n if (arraysEqual(guardValues, this.guardValues)) return;\n this.activated.dispose();\n }\n this.guardValues = guardValues;\n const activated = (this.activated = new RefCounted());\n callback(activated);\n this.isActiveChanged.dispatch();\n }\n\n deactivate(error: string) {\n this.messages.clearMessages();\n this.messages.addMessage({\n severity: MessageSeverity.error,\n message: error,\n });\n const { activated } = this;\n if (activated === undefined) return;\n this.activated = undefined;\n activated.dispose();\n this.isActiveChanged.dispatch();\n }\n\n addRenderLayer(renderLayer: Owned) {\n const activated = this.activated!;\n activated.registerDisposer(\n this.loadedDataSource.layer.addRenderLayer(renderLayer),\n );\n activated.registerDisposer(this.messages.addChild(renderLayer.messages));\n }\n\n getRenderLayerTransform(\n channelCoordinateSpace?: WatchableValueInterface,\n ) {\n const activated = this.activated!;\n const { layer, transform } = this.loadedDataSource;\n return activated.registerDisposer(\n getWatchableRenderLayerTransform(\n layer.manager.root.coordinateSpace,\n layer.localPosition.coordinateSpace,\n transform,\n this,\n channelCoordinateSpace,\n ),\n );\n }\n}\n\nexport class LoadedLayerDataSource extends RefCounted {\n error = undefined;\n enabledSubsourcesChanged = new NullarySignal();\n activatedSubsourcesChanged = new NullarySignal();\n messages = new MessageList();\n transform: WatchableCoordinateSpaceTransform;\n subsources: LoadedDataSubsource[];\n enableDefaultSubsources: boolean;\n get enabledSubsources() {\n return this.subsources.filter((x) => x.enabled);\n }\n get layer() {\n return this.layerDataSource.layer;\n }\n constructor(\n public layerDataSource: LayerDataSource,\n public dataSource: DataSource,\n spec: DataSourceSpecification,\n ) {\n super();\n if (dataSource.canChangeModelSpaceRank) {\n this.transform = new WatchableCoordinateSpaceTransform(\n makeIdentityTransform(\n makeCoordinateSpace({\n rank: 0,\n scales: new Float64Array(0),\n units: [],\n names: [],\n }),\n ),\n true,\n );\n this.transform.value = dataSource.modelTransform;\n } else {\n this.transform = new WatchableCoordinateSpaceTransform(\n dataSource.modelTransform,\n );\n }\n if (spec.transform !== undefined) {\n this.transform.spec = spec.transform;\n }\n const subsourceSpecs = spec.subsources;\n this.enableDefaultSubsources = spec.enableDefaultSubsources;\n this.subsources = dataSource.subsources.map(\n (subsourceEntry, subsourceIndex): LoadedDataSubsource =>\n new LoadedDataSubsource(\n this,\n subsourceEntry,\n subsourceSpecs.get(subsourceEntry.id),\n subsourceIndex,\n this.enableDefaultSubsources,\n ),\n );\n }\n\n disposed() {\n for (const subsource of this.subsources) {\n const { activated } = subsource;\n if (activated !== undefined) {\n subsource.activated = undefined;\n activated.dispose();\n }\n }\n }\n}\n\nexport type LayerDataSourceLoadState =\n | {\n error: Error;\n }\n | LoadedLayerDataSource\n | undefined;\n\nexport class LayerDataSource extends RefCounted {\n changed = new NullarySignal();\n messages = new MessageList();\n private loadState_: LayerDataSourceLoadState = undefined;\n private spec_: DataSourceSpecification;\n private specGeneration = -1;\n private refCounted_: RefCounted | undefined = undefined;\n\n constructor(\n public layer: Borrowed,\n spec: DataSourceSpecification | undefined = undefined,\n ) {\n super();\n this.registerDisposer(this.changed.add(layer.dataSourcesChanged.dispatch));\n this.registerDisposer(layer.messages.addChild(this.messages));\n if (spec === undefined) {\n this.spec_ = makeEmptyDataSourceSpecification();\n } else {\n this.spec = spec;\n }\n }\n\n get spec() {\n const { loadState } = this;\n if (loadState !== undefined && loadState.error === undefined) {\n const generation = this.changed.count;\n if (generation !== this.specGeneration) {\n this.specGeneration = generation;\n this.spec_ = {\n url: this.spec.url,\n transform: loadState.transform.spec,\n enableDefaultSubsources: loadState.enableDefaultSubsources,\n subsources: new Map(\n Array.from(loadState.subsources, (loadedSubsource) => {\n const defaultEnabledValue =\n loadState.enableDefaultSubsources &&\n loadedSubsource.subsourceEntry.default;\n return [\n loadedSubsource.subsourceEntry.id,\n {\n enabled:\n loadedSubsource.enabled !== defaultEnabledValue\n ? loadedSubsource.enabled\n : undefined,\n },\n ];\n }),\n ),\n state: this.spec.state,\n };\n }\n }\n return this.spec_;\n }\n\n get loadState() {\n return this.loadState_;\n }\n\n set spec(spec: DataSourceSpecification) {\n const { layer } = this;\n this.messages.clearMessages();\n if (spec.url.length === 0) {\n if (layer.dataSources.length !== 1) {\n const index = layer.dataSources.indexOf(this);\n if (index !== -1) {\n layer.dataSources.splice(index, 1);\n layer.dataSourcesChanged.dispatch();\n this.dispose();\n return;\n }\n }\n this.spec_ = spec;\n if (this.refCounted_ !== undefined) {\n this.refCounted_.dispose();\n this.refCounted_ = undefined;\n this.loadState_ = undefined;\n this.changed.dispatch();\n }\n return;\n }\n const refCounted = new RefCounted();\n const retainer = refCounted.registerDisposer(\n disposableOnce(layer.markLoading()),\n );\n if (this.refCounted_ !== undefined) {\n this.refCounted_.dispose();\n this.loadState_ = undefined;\n }\n this.refCounted_ = refCounted;\n this.spec_ = spec;\n const chunkManager = layer.manager.chunkManager;\n const registry = layer.manager.dataSourceProviderRegistry;\n const cancellationToken = new CancellationTokenSource();\n this.messages.addMessage({\n severity: MessageSeverity.info,\n message: \"Loading data source\",\n });\n registry\n .get({\n chunkManager,\n url: spec.url,\n cancellationToken,\n globalCoordinateSpace: layer.manager.root.coordinateSpace,\n transform: spec.transform,\n state: spec.state,\n })\n .then((source: DataSource) => {\n if (refCounted.wasDisposed) return;\n this.messages.clearMessages();\n const loaded = refCounted.registerDisposer(\n new LoadedLayerDataSource(this, source, spec),\n );\n loaded.registerDisposer(\n layer.addCoordinateSpace(loaded.transform.outputSpace),\n );\n loaded.registerDisposer(\n loaded.transform.changed.add(this.changed.dispatch),\n );\n this.loadState_ = loaded;\n loaded.registerDisposer(\n loaded.enabledSubsourcesChanged.add(this.changed.dispatch),\n );\n this.changed.dispatch();\n if (source.state) {\n refCounted.registerDisposer(\n source.state.changed.add(() => {\n this.spec.state = source.state?.toJSON();\n layer.specificationChanged.dispatch();\n }),\n );\n }\n retainer();\n })\n .catch((error: Error) => {\n if (this.wasDisposed) return;\n this.loadState_ = { error };\n this.messages.clearMessages();\n this.messages.addMessage({\n severity: MessageSeverity.error,\n message: error.message,\n });\n this.changed.dispatch();\n });\n refCounted.registerDisposer(() => {\n cancellationToken.cancel();\n });\n this.changed.dispatch();\n }\n\n disposed() {\n const refCounted = this.refCounted_;\n if (refCounted !== undefined) {\n refCounted.dispose();\n }\n }\n\n toJSON() {\n const { loadState } = this;\n if (loadState === undefined || loadState.error !== undefined) {\n return layerDataSourceSpecificationToJson(this.spec);\n }\n return layerDataSourceSpecificationToJson({\n url: this.spec.url,\n transform: loadState.transform.spec,\n enableDefaultSubsources: loadState.enableDefaultSubsources,\n subsources: new Map(\n Array.from(loadState.subsources, (loadedSubsource) => {\n const defaultEnabledValue =\n loadState.enableDefaultSubsources &&\n loadedSubsource.subsourceEntry.default;\n return [\n loadedSubsource.subsourceEntry.id,\n {\n enabled:\n loadedSubsource.enabled !== defaultEnabledValue\n ? loadedSubsource.enabled\n : undefined,\n },\n ];\n }),\n ),\n state: this.spec.state,\n });\n }\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport {\n verifyBoolean,\n verifyFiniteFloat,\n verifyObject,\n verifyOptionalObjectProperty,\n verifyPositiveInt,\n} from \"#src/util/json.js\";\nimport { Signal } from \"#src/util/signal.js\";\nimport type { Trackable } from \"#src/util/trackable.js\";\n\nexport type Side = \"left\" | \"right\" | \"top\" | \"bottom\";\n\nexport const DEFAULT_SIDE_PANEL_WIDTH = 300;\nexport const DEFAULT_MIN_SIDE_PANEL_WIDTH = 100;\n\nexport interface SidePanelLocation {\n // Side on which the panel is located.\n side: Side;\n\n // Horizontal position as ordinal.\n col: number;\n\n // Vertical position as ordinal.\n row: number;\n\n // Fraction of full size along flex direction.\n flex: number;\n\n // Cross-direction size in pixels.\n size: number;\n\n // Minimum width in pixels.\n minSize: number;\n\n // Whether the panel is visible.\n visible: boolean;\n}\n\nexport const DEFAULT_SIDE_PANEL_LOCATION: SidePanelLocation = {\n side: \"right\",\n col: 0,\n row: Infinity,\n flex: 1,\n size: DEFAULT_SIDE_PANEL_WIDTH,\n minSize: DEFAULT_MIN_SIDE_PANEL_WIDTH,\n visible: false,\n};\n\nexport class TrackableSidePanelLocation implements Trackable {\n // Indicates that the JSON representation changed. Note that some changes are just due to\n // normalization and don't affect the actual layout.\n changed = new Signal();\n\n // Indicates that the layout actually changed.\n locationChanged = new Signal();\n\n readonly watchableVisible: WatchableValueInterface;\n\n constructor(\n public defaultValue: SidePanelLocation = DEFAULT_SIDE_PANEL_LOCATION,\n public value = defaultValue,\n ) {\n this.locationChanged.add(this.changed.dispatch);\n const self = this;\n this.watchableVisible = {\n get value() {\n return self.visible;\n },\n set value(value: boolean) {\n self.visible = value;\n },\n changed: self.locationChanged,\n };\n }\n\n toJSON(defaultValue = this.defaultValue) {\n const obj: any = {};\n const { value } = this;\n for (const key in value) {\n if (\n value[key as keyof SidePanelLocation] ===\n defaultValue[key as keyof SidePanelLocation]\n ) {\n continue;\n }\n obj[key] = value[key as keyof SidePanelLocation];\n }\n return obj;\n }\n\n get visible() {\n return this.value.visible;\n }\n\n set visible(visible: boolean) {\n const { value } = this;\n if (value.visible !== visible) {\n this.value = { ...value, visible };\n this.locationChanged.dispatch();\n }\n }\n\n reset() {\n if (this.value !== this.defaultValue) {\n this.value = this.defaultValue;\n this.locationChanged.dispatch();\n }\n }\n\n restoreState(obj: unknown, defaultLocation = this.defaultValue) {\n if (obj === undefined) return;\n verifyObject(obj);\n const location: SidePanelLocation = {\n side: verifyOptionalObjectProperty(\n obj,\n \"side\",\n (x) => {\n if (x !== \"left\" && x !== \"right\" && x !== \"top\" && x !== \"bottom\") {\n throw new Error(\n `Expected \"left\", \"right\", \"top\", or \"bottom\", but received: ${JSON.stringify(\n x,\n )}`,\n );\n }\n return x;\n },\n defaultLocation.side,\n ),\n col: verifyOptionalObjectProperty(\n obj,\n \"col\",\n verifyFiniteFloat,\n defaultLocation.col,\n ),\n row: verifyOptionalObjectProperty(\n obj,\n \"row\",\n verifyFiniteFloat,\n defaultLocation.row,\n ),\n flex: verifyOptionalObjectProperty(\n obj,\n \"flex\",\n verifyFiniteFloat,\n defaultLocation.flex,\n ),\n size: verifyOptionalObjectProperty(\n obj,\n \"size\",\n verifyPositiveInt,\n defaultLocation.size,\n ),\n visible: verifyOptionalObjectProperty(\n obj,\n \"visible\",\n verifyBoolean,\n defaultLocation.visible,\n ),\n // minSize cannot be modified.\n minSize: defaultLocation.minSize,\n };\n this.value = location;\n this.locationChanged.dispatch();\n }\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { UserLayer } from \"#src/layer/index.js\";\nimport { WatchableValue } from \"#src/trackable_value.js\";\nimport type { SidePanelLocation } from \"#src/ui/side_panel_location.js\";\nimport {\n DEFAULT_SIDE_PANEL_LOCATION,\n TrackableSidePanelLocation,\n} from \"#src/ui/side_panel_location.js\";\nimport { arraysEqual } from \"#src/util/array.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport {\n parseArray,\n verifyObject,\n verifyOptionalObjectProperty,\n verifyString,\n verifyStringArray,\n} from \"#src/util/json.js\";\nimport { Signal } from \"#src/util/signal.js\";\n\nconst TAB_JSON_KEY = \"tab\";\nconst TABS_JSON_KEY = \"tabs\";\nconst PANELS_JSON_KEY = \"panels\";\n\nexport const SELECTED_LAYER_SIDE_PANEL_DEFAULT_LOCATION = {\n ...DEFAULT_SIDE_PANEL_LOCATION,\n row: 0,\n};\nexport const LAYER_SIDE_PANEL_DEFAULT_LOCATION = {\n ...DEFAULT_SIDE_PANEL_LOCATION,\n visible: true,\n row: 0,\n};\n\nexport class UserLayerSidePanelState extends RefCounted {\n layer = this.panels.layer;\n location = new TrackableSidePanelLocation(LAYER_SIDE_PANEL_DEFAULT_LOCATION);\n constructor(public panels: UserLayerSidePanelsState) {\n super();\n }\n\n initialize() {\n const { panels } = this;\n this.tabsChanged.add(panels.specificationChanged.dispatch);\n this.selectedTab.changed.add(panels.specificationChanged.dispatch);\n this.location.changed.add(() => {\n panels.specificationChanged.dispatch();\n const { layer } = this;\n const { selectedLayer } = layer.manager.root;\n if (selectedLayer.layer?.layer !== layer) return;\n if (this !== layer.panels.panels[0]) return;\n const curLocation = this.location.value;\n if (selectedLayer.location.value !== curLocation) {\n selectedLayer.location.value = curLocation;\n selectedLayer.location.locationChanged.dispatch();\n }\n });\n this.location.locationChanged.add(() => {\n if (this.location.visible) return;\n if (this === this.panels.panels[0]) return;\n this.panels.removePanel(this);\n });\n\n // TODO, is it safe to put this here?\n for (const id of this.tabs) {\n const { hidden } = this.layer.tabs.options.get(id)!;\n if (hidden) {\n this.registerDisposer(\n hidden.changed.add(() => {\n this.panels.updateTabs();\n this.tabsChanged.dispatch();\n }),\n );\n }\n }\n }\n tabsChanged = new Signal();\n selectedTab = new WatchableValue(undefined);\n explicitTabs: Set | undefined;\n tabs: string[] = [];\n\n normalizeTabs() {\n const { tabs } = this;\n if (tabs.length === 0) {\n this.selectedTab.value = undefined;\n return;\n }\n const layerTabs = this.layer.tabs.options;\n const getOrder = (tab: string) => layerTabs.get(tab)!.order ?? 0;\n tabs.sort((a, b) => getOrder(a) - getOrder(b));\n const { selectedTab } = this;\n const selectedTabValue = selectedTab.value;\n if (selectedTabValue === undefined || !tabs.includes(selectedTabValue)) {\n selectedTab.value = tabs[0];\n }\n }\n\n pin() {\n // \"Pin\" this panel, which means converting it from the selected layer panel to an extra panel.\n const { layer } = this;\n const { selectedLayer } = layer.manager.root;\n // Check that this is the selected layer panel.\n if (selectedLayer.layer?.layer !== layer) return;\n if (this !== layer.panels.panels[0]) return;\n if (this.tabs.length === 0) return;\n const { panels } = this;\n const newPanel = layer.registerDisposer(\n new UserLayerSidePanelState(panels),\n );\n panels.panels.splice(0, 1, newPanel);\n panels.panels.push(this);\n panels.updateTabs();\n newPanel.initialize();\n selectedLayer.layerManager.layersChanged.dispatch();\n this.panels.specificationChanged.dispatch();\n }\n\n unpin() {\n // \"Unpin\" this panel, which means pinning the current selected layer panel, if any, and making\n // this panel the selected layer panel.\n const { panels } = this;\n const panelIndex = panels.panels.indexOf(this);\n if (panelIndex === -1 || panelIndex === 0) return;\n const { layer } = this;\n const { selectedLayer } = layer.manager.root;\n const selectedUserLayer = selectedLayer.layer?.layer;\n if (\n selectedLayer.visible &&\n selectedUserLayer != null &&\n selectedUserLayer !== layer\n ) {\n const prevSelectedLayerPanel = selectedUserLayer.panels.panels[0];\n prevSelectedLayerPanel.pin();\n }\n panels.panels.splice(panelIndex, 1);\n const [origSelectedPanel] = panels.panels.splice(0, 1, this);\n if (this.explicitTabs === undefined) {\n // This layer will contain all remaining tabs. The old selected layer panel should be\n // removed, as otherwise `updateTabs` will incorrectly assign it all tabs.\n layer.unregisterDisposer(origSelectedPanel);\n } else {\n panels.panels.push(origSelectedPanel);\n // This layer will contain only the explicit tabs. All other extra layers must be set to have\n // explicit tabs as well, as otherwise `updateTabs` will assign all tabs to them.\n for (let i = 1, length = panels.panels.length; i < length; ++i) {\n const panel = panels.panels[i];\n if (panel.explicitTabs === undefined) {\n panel.explicitTabs = new Set(panel.tabs);\n }\n }\n }\n this.explicitTabs = undefined;\n panels.updateTabs();\n selectedLayer.layer = layer.managedLayer;\n selectedLayer.location.value = this.location.value;\n selectedLayer.location.locationChanged.dispatch();\n selectedLayer.layerManager.layersChanged.dispatch();\n this.panels.specificationChanged.dispatch();\n }\n\n splitOffTab(tab: string, location: SidePanelLocation) {\n // Move the specified tab to a new panel.\n if (!this.tabs.includes(tab)) return;\n const { panels } = this;\n {\n const { explicitTabs } = this;\n if (explicitTabs !== undefined) {\n explicitTabs.delete(tab);\n }\n }\n const { layer } = this;\n const newPanel = layer.registerDisposer(\n new UserLayerSidePanelState(panels),\n );\n newPanel.location.value = location;\n newPanel.explicitTabs = new Set([tab]);\n panels.panels.splice(1, 0, newPanel);\n panels.updateTabs();\n newPanel.initialize();\n layer.manager.root.layerManager.layersChanged.dispatch();\n panels.specificationChanged.dispatch();\n }\n\n moveTabTo(tab: string, target: UserLayerSidePanelState) {\n if (!this.tabs.includes(tab)) return;\n {\n const { explicitTabs } = this;\n if (explicitTabs !== undefined) {\n explicitTabs.delete(tab);\n }\n }\n {\n const { explicitTabs } = target;\n if (explicitTabs !== undefined) {\n explicitTabs.add(tab);\n }\n }\n const { panels } = this;\n panels.updateTabs();\n target.selectedTab.value = tab;\n panels.specificationChanged.dispatch();\n }\n\n mergeInto(target: UserLayerSidePanelState) {\n const { explicitTabs } = target;\n if (explicitTabs !== undefined) {\n for (const tab of this.tabs) {\n explicitTabs.add(tab);\n }\n }\n const { panels } = this;\n panels.removePanel(this);\n }\n}\n\nexport class UserLayerSidePanelsState {\n panels: UserLayerSidePanelState[];\n specificationChanged = new Signal();\n updating = false;\n constructor(public layer: UserLayer) {\n this.panels = [layer.registerDisposer(new UserLayerSidePanelState(this))];\n }\n\n restoreState(obj: unknown) {\n const { panels } = this;\n panels[0].selectedTab.value = verifyOptionalObjectProperty(\n obj,\n TAB_JSON_KEY,\n verifyString,\n );\n const { layer } = this;\n const { tabs } = layer;\n const availableTabs = new Set(tabs.options.keys());\n verifyOptionalObjectProperty(obj, PANELS_JSON_KEY, (panelsObj) =>\n parseArray(panelsObj, (panelObj) => {\n verifyObject(panelObj);\n const panel = new UserLayerSidePanelState(this);\n panel.location.restoreState(panelObj);\n if (!panel.location.visible) return;\n panel.selectedTab.value = verifyOptionalObjectProperty(\n panelObj,\n TAB_JSON_KEY,\n verifyString,\n );\n panel.explicitTabs = verifyOptionalObjectProperty(\n panelObj,\n TABS_JSON_KEY,\n (tabsObj) => {\n const curTabs = new Set();\n for (const tab of verifyStringArray(tabsObj)) {\n if (!availableTabs.has(tab)) continue;\n availableTabs.delete(tab);\n curTabs.add(tab);\n }\n return curTabs;\n },\n );\n if (panel.explicitTabs === undefined) {\n panel.tabs = Array.from(availableTabs);\n availableTabs.clear();\n } else {\n panel.tabs = Array.from(panel.explicitTabs);\n }\n if (panel.tabs.length === 0) return;\n panel.normalizeTabs();\n layer.registerDisposer(panel);\n panel.initialize();\n panels.push(panel);\n }),\n );\n panels[0].tabs = Array.from(availableTabs);\n panels[0].normalizeTabs();\n this.panels[0].initialize();\n }\n\n removePanel(panel: UserLayerSidePanelState) {\n if (this.updating) return;\n const i = this.panels.indexOf(panel);\n this.panels.splice(i, 1);\n this.layer.unregisterDisposer(panel);\n this.updateTabs();\n }\n\n updateTabs() {\n const { layer } = this;\n const { tabs } = layer;\n const availableTabs = new Set(tabs.options.keys());\n const { panels } = this;\n this.updating = true;\n const updatePanelTabs = (panel: UserLayerSidePanelState) => {\n const oldTabs = panel.tabs;\n if (panel.explicitTabs === undefined) {\n panel.tabs = Array.from(availableTabs);\n availableTabs.clear();\n } else {\n panel.tabs = Array.from(panel.explicitTabs);\n for (const tab of panel.tabs) {\n availableTabs.delete(tab);\n }\n }\n if (!arraysEqual(oldTabs, panel.tabs)) {\n panel.normalizeTabs();\n panel.tabsChanged.dispatch();\n }\n };\n for (let i = 1; i < panels.length; ) {\n const panel = panels[i];\n if (panel.location.visible) {\n updatePanelTabs(panel);\n if (panel.tabs.length !== 0) {\n ++i;\n continue;\n }\n }\n panels.splice(i, 1);\n layer.unregisterDisposer(panel);\n }\n updatePanelTabs(panels[0]);\n if (panels[0].tabs.length === 0) {\n const { selectedLayer } = this.layer.manager.root;\n if (selectedLayer.layer?.layer === this.layer) {\n selectedLayer.location.visible = false;\n }\n }\n this.updating = false;\n }\n\n toJSON() {\n const { panels } = this;\n const obj: any = {};\n obj[TAB_JSON_KEY] = panels[0].selectedTab.value;\n if (panels.length > 1) {\n const panelsObj: any[] = [];\n for (let i = 1, numPanels = panels.length; i < numPanels; ++i) {\n const panel = panels[i];\n const panelObj = panel.location.toJSON() ?? {};\n panelObj[TAB_JSON_KEY] = panel.selectedTab.value;\n const { explicitTabs } = panel;\n if (explicitTabs !== undefined) {\n panelObj[TABS_JSON_KEY] = Array.from(explicitTabs);\n }\n panelsObj.push(panelObj);\n }\n obj[PANELS_JSON_KEY] = panelsObj;\n }\n return obj;\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { Signal } from \"#src/util/signal.js\";\n\nexport function removeSignalBinding(\n signal: Signal,\n handler: T,\n) {\n signal.remove(handler);\n}\n\nexport function addSignalBinding(\n signal: Signal,\n handler: T,\n) {\n signal.add(handler);\n}\n\nexport interface SignalBindingUpdater {\n (signal: Signal, handler: T): void;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { debounce, throttle } from \"lodash-es\";\nimport type { AnnotationLayerState } from \"#src/annotation/annotation_layer_state.js\";\nimport type { AnnotationType } from \"#src/annotation/index.js\";\nimport type { ChunkManager } from \"#src/chunk_manager/frontend.js\";\nimport type {\n CoordinateSpace,\n CoordinateTransformSpecification,\n} from \"#src/coordinate_transform.js\";\nimport {\n CoordinateSpaceCombiner,\n coordinateTransformSpecificationFromLegacyJson,\n emptyInvalidCoordinateSpace,\n isGlobalDimension,\n isLocalDimension,\n isLocalOrChannelDimension,\n TrackableCoordinateSpace,\n} from \"#src/coordinate_transform.js\";\nimport type {\n DataSourceProviderRegistry,\n DataSourceSpecification,\n DataSubsource,\n} from \"#src/datasource/index.js\";\nimport { makeEmptyDataSourceSpecification } from \"#src/datasource/index.js\";\nimport type { DisplayContext, RenderedPanel } from \"#src/display_context.js\";\nimport type { LoadedDataSubsource } from \"#src/layer/layer_data_source.js\";\nimport {\n LayerDataSource,\n layerDataSourceSpecificationFromJson,\n} from \"#src/layer/layer_data_source.js\";\nimport type {\n DisplayDimensions,\n WatchableDisplayDimensionRenderInfo,\n} from \"#src/navigation_state.js\";\nimport {\n CoordinateSpacePlaybackVelocity,\n PlaybackManager,\n Position,\n} from \"#src/navigation_state.js\";\nimport type { RenderLayerTransform } from \"#src/render_coordinate_transform.js\";\nimport {\n RENDERED_VIEW_ADD_LAYER_RPC_ID,\n RENDERED_VIEW_REMOVE_LAYER_RPC_ID,\n} from \"#src/render_layer_common.js\";\nimport type {\n RenderLayer,\n RenderLayerRole,\n VisibilityTrackedRenderLayer,\n} from \"#src/renderlayer.js\";\nimport type { VolumeType } from \"#src/sliceview/volume/base.js\";\nimport { StatusMessage } from \"#src/status.js\";\nimport { TrackableBoolean } from \"#src/trackable_boolean.js\";\nimport type {\n TrackableValueInterface,\n WatchableSet,\n WatchableValueInterface,\n} from \"#src/trackable_value.js\";\nimport { registerNested, WatchableValue } from \"#src/trackable_value.js\";\nimport {\n SELECTED_LAYER_SIDE_PANEL_DEFAULT_LOCATION,\n UserLayerSidePanelsState,\n} from \"#src/ui/layer_side_panel_state.js\";\nimport {\n DEFAULT_SIDE_PANEL_LOCATION,\n TrackableSidePanelLocation,\n} from \"#src/ui/side_panel_location.js\";\nimport type { GlobalToolBinder } from \"#src/ui/tool.js\";\nimport { LocalToolBinder, SelectedLegacyTool } from \"#src/ui/tool.js\";\nimport { gatherUpdate } from \"#src/util/array.js\";\nimport type { Borrowed, Owned } from \"#src/util/disposable.js\";\nimport { invokeDisposers, RefCounted } from \"#src/util/disposable.js\";\nimport {\n emptyToUndefined,\n parseArray,\n parseFixedLengthArray,\n verifyBoolean,\n verifyFiniteFloat,\n verifyInt,\n verifyObject,\n verifyObjectProperty,\n verifyOptionalObjectProperty,\n verifyOptionalString,\n verifyString,\n} from \"#src/util/json.js\";\nimport { MessageList } from \"#src/util/message_list.js\";\nimport type { AnyConstructor } from \"#src/util/mixin.js\";\nimport { NullarySignal, Signal } from \"#src/util/signal.js\";\nimport type { SignalBindingUpdater } from \"#src/util/signal_binding_updater.js\";\nimport {\n addSignalBinding,\n removeSignalBinding,\n} from \"#src/util/signal_binding_updater.js\";\nimport type { Trackable } from \"#src/util/trackable.js\";\nimport { Uint64 } from \"#src/util/uint64.js\";\nimport { kEmptyFloat32Vec } from \"#src/util/vector.js\";\nimport type { WatchableVisibilityPriority } from \"#src/visibility_priority/frontend.js\";\nimport type { DependentViewContext } from \"#src/widget/dependent_view_widget.js\";\nimport type { Tab } from \"#src/widget/tab_view.js\";\nimport { TabSpecification } from \"#src/widget/tab_view.js\";\nimport type { RPC } from \"#src/worker_rpc.js\";\n\nconst TOOL_JSON_KEY = \"tool\";\nconst TOOL_BINDINGS_JSON_KEY = \"toolBindings\";\nconst LOCAL_POSITION_JSON_KEY = \"localPosition\";\nconst LOCAL_VELOCITY_JSON_KEY = \"localVelocity\";\nconst LOCAL_COORDINATE_SPACE_JSON_KEY = \"localDimensions\";\nconst SOURCE_JSON_KEY = \"source\";\nconst TRANSFORM_JSON_KEY = \"transform\";\nconst PICK_JSON_KEY = \"pick\";\n\nexport interface UserLayerSelectionState {\n generation: number;\n\n // If `false`, selection is not associated with a position.\n localPositionValid: boolean;\n localPosition: Float32Array;\n localCoordinateSpace: CoordinateSpace | undefined;\n\n annotationId: string | undefined;\n annotationType: AnnotationType | undefined;\n annotationBuffer: Uint8Array | undefined;\n annotationIndex: number | undefined;\n annotationCount: number | undefined;\n annotationSourceIndex: number | undefined;\n annotationSubsource: string | undefined;\n annotationSubsubsourceId: string | undefined;\n annotationPartIndex: number | undefined;\n\n value: any;\n}\n\nexport class LayerActionContext {\n callbacks: (() => void)[] = [];\n defer(callback: () => void) {\n this.callbacks.push(callback);\n }\n}\n\nexport interface UserLayerTab {\n id: string;\n label: string;\n order: number;\n getter: (layer: UserLayer) => Tab;\n}\n\nexport const USER_LAYER_TABS: UserLayerTab[] = [];\n\nexport class UserLayer extends RefCounted {\n get localPosition() {\n return this.managedLayer.localPosition;\n }\n\n get localVelocity() {\n return this.managedLayer.localVelocity;\n }\n\n get localCoordinateSpaceCombiner() {\n return this.managedLayer.localCoordinateSpaceCombiner;\n }\n\n get localCoordinateSpace() {\n return this.managedLayer.localCoordinateSpace;\n }\n\n static type: string;\n static typeAbbreviation: string;\n\n get type() {\n return (this.constructor as typeof UserLayer).type;\n }\n\n static supportsPickOption = false;\n\n pick = new TrackableBoolean(true, true);\n\n selectionState: UserLayerSelectionState;\n\n messages = new MessageList();\n\n layerEventListeners = new Map();\n\n dispatchLayerEvent(type: string) {\n this.layerEventListeners.get(type)?.dispatch();\n }\n\n registerLayerEvent(type: string, handler: () => void) {\n const { layerEventListeners } = this;\n let existingSignal = layerEventListeners.get(type);\n if (!existingSignal) {\n existingSignal = new Signal();\n layerEventListeners.set(type, existingSignal);\n }\n const unregister = existingSignal.add(handler);\n return () => {\n const res = unregister();\n // TODO delete from layerEventListeners if no other handlers attached? currently Signal.handlers is private\n /*\n if (existingSignal.handlers.length === 0) {\n layerEventListeners.delete(type);\n }\n */\n return res;\n };\n }\n\n initializeSelectionState(state: this[\"selectionState\"]) {\n state.generation = -1;\n state.localPositionValid = false;\n state.localPosition = kEmptyFloat32Vec;\n state.localCoordinateSpace = undefined;\n state.annotationId = undefined;\n state.annotationType = undefined;\n state.annotationBuffer = undefined;\n state.annotationIndex = undefined;\n state.annotationCount = undefined;\n state.annotationSourceIndex = undefined;\n state.annotationSubsource = undefined;\n state.annotationPartIndex = undefined;\n state.value = undefined;\n }\n\n resetSelectionState(state: this[\"selectionState\"]) {\n state.localPositionValid = false;\n state.annotationId = undefined;\n state.value = undefined;\n }\n\n selectionStateFromJson(state: this[\"selectionState\"], json: any) {\n const localCoordinateSpace = (state.localCoordinateSpace =\n this.localCoordinateSpace.value);\n const { rank } = localCoordinateSpace;\n if (rank !== 0) {\n const localPosition = verifyOptionalObjectProperty(\n json,\n LOCAL_POSITION_JSON_KEY,\n (positionObj) =>\n parseFixedLengthArray(\n new Float32Array(rank),\n positionObj,\n verifyFiniteFloat,\n ),\n );\n if (localPosition === undefined) {\n state.localPositionValid = false;\n } else {\n state.localPositionValid = true;\n state.localPosition = localPosition;\n }\n }\n const annotationId = (state.annotationId = verifyOptionalObjectProperty(\n json,\n \"annotationId\",\n verifyString,\n ));\n if (annotationId !== undefined) {\n state.annotationSourceIndex = verifyOptionalObjectProperty(\n json,\n \"annotationSource\",\n verifyInt,\n 0,\n );\n state.annotationPartIndex = verifyOptionalObjectProperty(\n json,\n \"annotationPart\",\n verifyInt,\n );\n state.annotationSubsource = verifyOptionalObjectProperty(\n json,\n \"annotationSubsource\",\n verifyString,\n );\n }\n\n state.value = json.value;\n }\n\n // Derived classes should override.\n displaySelectionState(\n state: this[\"selectionState\"],\n parent: HTMLElement,\n context: DependentViewContext,\n ) {\n state;\n parent;\n context;\n return false;\n }\n\n selectionStateToJson(state: this[\"selectionState\"], forPython: boolean): any {\n forPython;\n const json: any = {};\n if (state.localPositionValid) {\n const { localPosition } = state;\n if (localPosition.length > 0) {\n json.localPosition = Array.from(localPosition);\n }\n }\n if (state.annotationId !== undefined) {\n json.annotationId = state.annotationId;\n json.annotationPart = state.annotationPartIndex;\n json.annotationSource = state.annotationSourceIndex;\n json.annotationSubsource = state.annotationSubsource;\n }\n if (state.value != null) {\n json.value = state.value;\n }\n return json;\n }\n\n captureSelectionState(\n state: this[\"selectionState\"],\n mouseState: MouseSelectionState,\n ) {\n state.localCoordinateSpace = this.localCoordinateSpace.value;\n const curLocalPosition = this.localPosition.value;\n const { localPosition } = state;\n if (localPosition.length !== curLocalPosition.length) {\n state.localPosition = curLocalPosition.slice();\n } else {\n localPosition.set(curLocalPosition);\n }\n state.localPositionValid = true;\n state.value = this.getValueAt(mouseState.position, mouseState);\n }\n\n copySelectionState(\n dest: this[\"selectionState\"],\n source: this[\"selectionState\"],\n ) {\n dest.generation = source.generation;\n dest.localPositionValid = source.localPositionValid;\n dest.localCoordinateSpace = source.localCoordinateSpace;\n const curLocalPosition = source.localPosition;\n const { localPosition } = dest;\n if (localPosition.length !== curLocalPosition.length) {\n dest.localPosition = curLocalPosition.slice();\n } else {\n dest.localPosition.set(curLocalPosition);\n }\n dest.annotationId = source.annotationId;\n dest.annotationType = source.annotationType;\n dest.annotationBuffer = source.annotationBuffer;\n dest.annotationIndex = source.annotationIndex;\n dest.annotationCount = source.annotationCount;\n dest.annotationSourceIndex = source.annotationSourceIndex;\n dest.annotationSubsource = source.annotationSubsource;\n dest.annotationPartIndex = source.annotationPartIndex;\n dest.value = source.value;\n }\n\n layersChanged = new NullarySignal();\n readyStateChanged = new NullarySignal();\n specificationChanged = new NullarySignal();\n renderLayers = new Array();\n private loadingCounter = 1;\n get isReady() {\n return this.loadingCounter === 0;\n }\n\n tabs = this.registerDisposer(new TabSpecification());\n panels = new UserLayerSidePanelsState(this);\n tool = this.registerDisposer(new SelectedLegacyTool(this));\n toolBinder = this.registerDisposer(\n new LocalToolBinder(this, this.manager.root.toolBinder),\n );\n\n dataSourcesChanged = new NullarySignal();\n dataSources: LayerDataSource[] = [];\n\n get manager() {\n return this.managedLayer.manager;\n }\n\n constructor(public managedLayer: Borrowed) {\n super();\n this.localCoordinateSpaceCombiner.includeDimensionPredicate =\n isLocalOrChannelDimension;\n this.tabs.changed.add(this.specificationChanged.dispatch);\n this.panels.specificationChanged.add(this.specificationChanged.dispatch);\n this.tool.changed.add(this.specificationChanged.dispatch);\n this.toolBinder.changed.add(this.specificationChanged.dispatch);\n this.localPosition.changed.add(this.specificationChanged.dispatch);\n this.pick.changed.add(this.specificationChanged.dispatch);\n this.pick.changed.add(this.layersChanged.dispatch);\n this.dataSourcesChanged.add(this.specificationChanged.dispatch);\n this.dataSourcesChanged.add(() => this.updateDataSubsourceActivations());\n this.messages.changed.add(this.layersChanged.dispatch);\n for (const tab of USER_LAYER_TABS) {\n this.tabs.add(tab.id, {\n label: tab.label,\n order: tab.order,\n getter: () => tab.getter(this),\n });\n }\n }\n\n canAddDataSource() {\n return true;\n }\n\n addDataSource(spec: DataSourceSpecification | undefined) {\n const layerDataSource = new LayerDataSource(this, spec);\n this.dataSources.push(layerDataSource);\n this.dataSourcesChanged.dispatch();\n return layerDataSource;\n }\n\n // Should be overridden by derived classes.\n activateDataSubsources(subsources: Iterable): void {\n subsources;\n }\n\n updateDataSubsourceActivations() {\n function* getDataSubsources(\n this: UserLayer,\n ): Iterable {\n for (const dataSource of this.dataSources) {\n const { loadState } = dataSource;\n if (loadState === undefined || loadState.error !== undefined) continue;\n for (const subsource of loadState.subsources) {\n if (subsource.enabled) {\n yield subsource;\n } else {\n const { activated } = subsource;\n subsource.messages.clearMessages();\n if (activated !== undefined) {\n activated.dispose();\n subsource.activated = undefined;\n loadState.activatedSubsourcesChanged.dispatch();\n }\n }\n }\n }\n }\n this.activateDataSubsources(getDataSubsources.call(this));\n }\n\n private decrementLoadingCounter() {\n if (--this.loadingCounter === 0) {\n this.readyStateChanged.dispatch();\n }\n }\n\n markLoading() {\n const localRetainer = this.localCoordinateSpaceCombiner.retain();\n const globalRetainer = this.manager.root.coordinateSpaceCombiner.retain();\n if (++this.loadingCounter === 1) {\n this.readyStateChanged.dispatch();\n }\n const disposer = () => {\n localRetainer();\n globalRetainer();\n this.decrementLoadingCounter();\n };\n return disposer;\n }\n\n addCoordinateSpace(\n coordinateSpace: WatchableValueInterface,\n ) {\n const globalBinding =\n this.manager.root.coordinateSpaceCombiner.bind(coordinateSpace);\n const localBinding =\n this.localCoordinateSpaceCombiner.bind(coordinateSpace);\n return () => {\n globalBinding();\n localBinding();\n };\n }\n\n initializationDone() {\n const selectionState = (this.selectionState = {} as any);\n this.initializeSelectionState(selectionState);\n this.decrementLoadingCounter();\n }\n\n getLegacyDataSourceSpecifications(\n sourceSpec: string | undefined,\n layerSpec: any,\n legacyTransform: CoordinateTransformSpecification | undefined,\n explicitSpecs: DataSourceSpecification[],\n ): DataSourceSpecification[] {\n layerSpec;\n explicitSpecs;\n if (sourceSpec === undefined) return [];\n return [layerDataSourceSpecificationFromJson(sourceSpec, legacyTransform)];\n }\n\n getDataSourceSpecifications(layerSpec: any): DataSourceSpecification[] {\n let legacySpec: any = undefined;\n let specs = verifyObjectProperty(\n layerSpec,\n SOURCE_JSON_KEY,\n (sourcesObj) => {\n if (Array.isArray(sourcesObj)) {\n return sourcesObj.map((source) =>\n layerDataSourceSpecificationFromJson(source),\n );\n }\n if (typeof sourcesObj === \"object\") {\n return [layerDataSourceSpecificationFromJson(sourcesObj)];\n }\n legacySpec = sourcesObj;\n return [];\n },\n );\n const legacyTransform = verifyObjectProperty(\n layerSpec,\n TRANSFORM_JSON_KEY,\n coordinateTransformSpecificationFromLegacyJson,\n );\n specs.push(\n ...this.getLegacyDataSourceSpecifications(\n legacySpec,\n layerSpec,\n legacyTransform,\n specs,\n ),\n );\n specs = specs.filter((spec) => spec.url);\n if (specs.length === 0) {\n specs.push(makeEmptyDataSourceSpecification());\n }\n return specs;\n }\n\n restoreState(specification: any) {\n this.tool.restoreState(specification[TOOL_JSON_KEY]);\n this.panels.restoreState(specification);\n this.localCoordinateSpace.restoreState(\n specification[LOCAL_COORDINATE_SPACE_JSON_KEY],\n );\n this.localPosition.restoreState(specification[LOCAL_POSITION_JSON_KEY]);\n this.localVelocity.restoreState(specification[LOCAL_VELOCITY_JSON_KEY]);\n this.toolBinder.restoreState(specification[TOOL_BINDINGS_JSON_KEY]);\n if ((this.constructor as typeof UserLayer).supportsPickOption) {\n this.pick.restoreState(specification[PICK_JSON_KEY]);\n }\n for (const spec of this.getDataSourceSpecifications(specification)) {\n this.addDataSource(spec);\n }\n }\n\n addRenderLayer(layer: Owned) {\n this.renderLayers.push(layer);\n const { layersChanged } = this;\n layer.layerChanged.add(layersChanged.dispatch);\n layer.userLayer = this;\n layersChanged.dispatch();\n return () => this.removeRenderLayer(layer);\n }\n\n removeRenderLayer(layer: RenderLayer) {\n const { renderLayers, layersChanged } = this;\n const index = renderLayers.indexOf(layer);\n if (index === -1) {\n throw new Error(\"Attempted to remove invalid RenderLayer\");\n }\n renderLayers.splice(index, 1);\n layer.layerChanged.remove(layersChanged.dispatch);\n layer.userLayer = undefined;\n layer.dispose();\n layersChanged.dispatch();\n }\n\n disposed() {\n const { layersChanged } = this;\n invokeDisposers(this.dataSources);\n for (const layer of this.renderLayers) {\n layer.layerChanged.remove(layersChanged.dispatch);\n layer.dispose();\n }\n this.renderLayers.length = 0;\n super.disposed();\n }\n\n getValueAt(position: Float32Array, pickState: PickState) {\n let result: any;\n const { renderLayers } = this;\n const { pickedRenderLayer } = pickState;\n if (\n pickedRenderLayer !== null &&\n renderLayers.indexOf(pickedRenderLayer) !== -1\n ) {\n result = pickedRenderLayer.transformPickedValue(pickState);\n result = this.transformPickedValue(result);\n if (result != null) return result;\n }\n for (const layer of renderLayers) {\n result = layer.getValueAt(position);\n if (result != null) {\n break;\n }\n }\n return this.transformPickedValue(result);\n }\n\n transformPickedValue(value: any) {\n return value;\n }\n\n toJSON(): any {\n return {\n type: this.type,\n [SOURCE_JSON_KEY]: dataSourcesToJson(this.dataSources),\n [TOOL_JSON_KEY]: this.tool.toJSON(),\n [TOOL_BINDINGS_JSON_KEY]: this.toolBinder.toJSON(),\n [LOCAL_COORDINATE_SPACE_JSON_KEY]: this.localCoordinateSpace.toJSON(),\n [LOCAL_POSITION_JSON_KEY]: this.localPosition.toJSON(),\n [LOCAL_VELOCITY_JSON_KEY]: this.localVelocity.toJSON(),\n [PICK_JSON_KEY]: this.pick.toJSON(),\n ...this.panels.toJSON(),\n };\n }\n\n // Derived classes should override.\n handleAction(_action: string, _context: LayerActionContext): void {}\n\n selectedValueToJson(value: any) {\n return value;\n }\n\n selectedValueFromJson(json: any) {\n return json;\n }\n\n setLayerPosition(\n modelTransform: RenderLayerTransform,\n layerPosition: Float32Array,\n ) {\n const { globalPosition } = this.manager.root;\n const { localPosition } = this;\n gatherUpdate(\n globalPosition.value,\n layerPosition,\n modelTransform.globalToRenderLayerDimensions,\n );\n gatherUpdate(\n localPosition.value,\n layerPosition,\n modelTransform.localToRenderLayerDimensions,\n );\n localPosition.changed.dispatch();\n globalPosition.changed.dispatch();\n }\n}\n\nfunction dataSourcesToJson(sources: readonly LayerDataSource[]) {\n if (sources.length === 0) return undefined;\n if (sources.length === 1) return sources[0].toJSON();\n return sources.map((x) => x.toJSON());\n}\n\nexport class ManagedUserLayer extends RefCounted {\n localCoordinateSpace = new TrackableCoordinateSpace();\n localCoordinateSpaceCombiner = new CoordinateSpaceCombiner(\n this.localCoordinateSpace,\n isLocalDimension,\n );\n localPosition = this.registerDisposer(\n new Position(this.localCoordinateSpace),\n );\n localVelocity = this.registerDisposer(\n new CoordinateSpacePlaybackVelocity(this.localCoordinateSpace),\n );\n\n // Index of layer within root layer manager, counting only non-archived layers. This is the layer\n // number shown in the layer bar and layer list panel.\n nonArchivedLayerIndex = -1;\n\n readyStateChanged = new NullarySignal();\n layerChanged = new NullarySignal();\n specificationChanged = new NullarySignal();\n containers = new Set>();\n private layer_: UserLayer | null = null;\n get layer() {\n return this.layer_;\n }\n private unregisterUserLayer: (() => void) | undefined;\n\n /**\n * If layer is not null, tranfers ownership of a reference.\n */\n set layer(layer: UserLayer | null) {\n const oldLayer = this.layer_;\n if (oldLayer != null) {\n this.unregisterUserLayer!();\n oldLayer.dispose();\n }\n this.layer_ = layer;\n if (layer != null) {\n const removers = [\n layer.layersChanged.add(this.layerChanged.dispatch),\n layer.readyStateChanged.add(this.readyStateChanged.dispatch),\n layer.specificationChanged.add(this.specificationChanged.dispatch),\n ];\n this.unregisterUserLayer = () => {\n removers.forEach((x) => x());\n };\n this.readyStateChanged.dispatch();\n this.layerChanged.dispatch();\n }\n }\n\n isReady() {\n const { layer } = this;\n return layer?.isReady;\n }\n\n private name_: string;\n\n get name() {\n return this.name_;\n }\n\n set name(value: string) {\n if (value !== this.name_) {\n this.name_ = value;\n this.layerChanged.dispatch();\n }\n }\n\n visible = true;\n archived = false;\n\n get supportsPickOption() {\n const userLayer = this.layer;\n return (\n userLayer !== null &&\n (userLayer.constructor as typeof UserLayer).supportsPickOption\n );\n }\n\n get pickEnabled() {\n const userLayer = this.layer;\n return (\n userLayer !== null &&\n (userLayer.constructor as typeof UserLayer).supportsPickOption &&\n userLayer.pick.value\n );\n }\n\n set pickEnabled(value: boolean) {\n const userLayer = this.layer;\n if (\n userLayer !== null &&\n (userLayer.constructor as typeof UserLayer).supportsPickOption\n ) {\n userLayer.pick.value = value;\n }\n }\n\n /**\n * If layer is not null, tranfers ownership of a reference.\n */\n constructor(\n name: string,\n public manager: Borrowed,\n ) {\n super();\n this.name_ = name;\n this.registerDisposer(\n new PlaybackManager(\n this.manager.root.display,\n this.localPosition,\n this.localVelocity,\n ),\n );\n }\n\n toJSON() {\n const userLayer = this.layer;\n if (userLayer === null) {\n return undefined;\n }\n const layerSpec = userLayer.toJSON();\n layerSpec.name = this.name;\n if (!this.visible) {\n if (this.archived) {\n layerSpec.archived = true;\n } else {\n layerSpec.visible = false;\n }\n }\n return layerSpec;\n }\n\n setVisible(value: boolean) {\n if (value === this.visible) return;\n if (value && this.archived) {\n this.visible = true;\n this.setArchived(false);\n return;\n }\n this.visible = value;\n this.layerChanged.dispatch();\n }\n\n setArchived(value: boolean) {\n if (this.archived === value) return;\n if (value === true) {\n this.visible = false;\n this.archived = true;\n for (const { layerManager } of this.manager.root.subsets) {\n if (!layerManager.has(this)) continue;\n layerManager.removeManagedLayer(this);\n }\n } else {\n for (const { layerManager } of this.manager.root.subsets) {\n if (layerManager.has(this)) continue;\n layerManager.addManagedLayer(this.addRef());\n }\n this.archived = false;\n }\n this.layerChanged.dispatch();\n }\n\n disposed() {\n this.layer = null;\n super.disposed();\n }\n}\n\nexport class LayerManager extends RefCounted {\n managedLayers = new Array>();\n layerSet = new Set>();\n layersChanged = new NullarySignal();\n readyStateChanged = new NullarySignal();\n specificationChanged = new NullarySignal();\n boundPositions = new WeakSet();\n numDirectUsers = 0;\n nonArchivedLayerIndexGeneration = -1;\n private renderLayerToManagedLayerMapGeneration = -1;\n private renderLayerToManagedLayerMap_ = new Map<\n RenderLayer,\n ManagedUserLayer\n >();\n\n constructor() {\n super();\n this.layersChanged.add(this.scheduleRemoveLayersWithSingleRef);\n }\n\n private scheduleRemoveLayersWithSingleRef = this.registerCancellable(\n debounce(() => this.removeLayersWithSingleRef(), 0),\n );\n\n updateNonArchivedLayerIndices() {\n const generation = this.layersChanged.count;\n if (generation === this.nonArchivedLayerIndexGeneration) return;\n this.nonArchivedLayerIndexGeneration = generation;\n let index = 0;\n for (const layer of this.managedLayers) {\n if (!layer.archived) {\n layer.nonArchivedLayerIndex = index++;\n }\n }\n for (const layer of this.managedLayers) {\n if (layer.archived) {\n layer.nonArchivedLayerIndex = index++;\n }\n }\n }\n\n getLayerByNonArchivedIndex(index: number): ManagedUserLayer | undefined {\n let i = 0;\n for (const layer of this.managedLayers) {\n if (!layer.archived) {\n if (i === index) return layer;\n ++i;\n }\n }\n return undefined;\n }\n\n get renderLayerToManagedLayerMap() {\n const generation = this.layersChanged.count;\n const map = this.renderLayerToManagedLayerMap_;\n if (this.renderLayerToManagedLayerMapGeneration !== generation) {\n this.renderLayerToManagedLayerMapGeneration = generation;\n map.clear();\n for (const managedLayer of this.managedLayers) {\n const userLayer = managedLayer.layer;\n if (userLayer !== null) {\n for (const renderLayer of userLayer.renderLayers) {\n map.set(renderLayer, managedLayer);\n }\n }\n }\n }\n return map;\n }\n\n filter(predicate: (layer: ManagedUserLayer) => boolean) {\n let changed = false;\n this.managedLayers = this.managedLayers.filter((layer) => {\n if (!predicate(layer)) {\n this.unbindManagedLayer(layer);\n this.layerSet.delete(layer);\n changed = true;\n return false;\n }\n return true;\n });\n if (changed) {\n this.layersChanged.dispatch();\n }\n }\n\n private removeLayersWithSingleRef() {\n if (this.numDirectUsers > 0) {\n return;\n }\n this.filter((layer) => layer.refCount !== 1 || layer.archived);\n }\n\n private updateSignalBindings(\n layer: ManagedUserLayer,\n callback: SignalBindingUpdater<() => void>,\n ) {\n callback(layer.layerChanged, this.layersChanged.dispatch);\n callback(layer.readyStateChanged, this.readyStateChanged.dispatch);\n callback(layer.specificationChanged, this.specificationChanged.dispatch);\n }\n\n useDirectly() {\n if (++this.numDirectUsers === 1) {\n this.layersChanged.remove(this.scheduleRemoveLayersWithSingleRef);\n }\n return () => {\n if (--this.numDirectUsers === 0) {\n this.layersChanged.add(this.scheduleRemoveLayersWithSingleRef);\n this.scheduleRemoveLayersWithSingleRef();\n }\n };\n }\n\n /**\n * Assumes ownership of an existing reference to managedLayer.\n */\n addManagedLayer(managedLayer: ManagedUserLayer, index?: number | undefined) {\n this.updateSignalBindings(managedLayer, addSignalBinding);\n this.layerSet.add(managedLayer);\n managedLayer.containers.add(this);\n if (index === undefined) {\n index = this.managedLayers.length;\n }\n this.managedLayers.splice(index, 0, managedLayer);\n this.layersChanged.dispatch();\n this.readyStateChanged.dispatch();\n return managedLayer;\n }\n\n *readyRenderLayers() {\n for (const managedUserLayer of this.managedLayers) {\n if (!managedUserLayer.visible || !managedUserLayer.layer) {\n continue;\n }\n yield* managedUserLayer.layer.renderLayers;\n }\n }\n\n unbindManagedLayer(managedLayer: ManagedUserLayer) {\n this.updateSignalBindings(managedLayer, removeSignalBinding);\n managedLayer.containers.delete(this);\n // Also notify the root LayerManager, to ensures the layer is removed if this is the last direct\n // reference.\n managedLayer.manager.rootLayers.layersChanged.dispatch();\n managedLayer.dispose();\n }\n\n clear() {\n for (const managedLayer of this.managedLayers) {\n this.unbindManagedLayer(managedLayer);\n }\n this.managedLayers.length = 0;\n this.layerSet.clear();\n this.layersChanged.dispatch();\n }\n\n remove(index: number) {\n const layer = this.managedLayers[index];\n this.unbindManagedLayer(layer);\n this.managedLayers.splice(index, 1);\n this.layerSet.delete(layer);\n this.layersChanged.dispatch();\n }\n\n removeManagedLayer(managedLayer: ManagedUserLayer) {\n const index = this.managedLayers.indexOf(managedLayer);\n if (index === -1) {\n throw new Error(\"Internal error: invalid managed layer.\");\n }\n this.remove(index);\n }\n\n reorderManagedLayer(oldIndex: number, newIndex: number) {\n const numLayers = this.managedLayers.length;\n if (\n oldIndex === newIndex ||\n oldIndex < 0 ||\n oldIndex >= numLayers ||\n newIndex < 0 ||\n newIndex >= numLayers\n ) {\n // Don't do anything.\n return;\n }\n const [oldLayer] = this.managedLayers.splice(oldIndex, 1);\n this.managedLayers.splice(newIndex, 0, oldLayer);\n this.layersChanged.dispatch();\n }\n\n disposed() {\n this.clear();\n super.disposed();\n }\n\n getLayerByName(name: string) {\n return this.managedLayers.find((x) => x.name === name);\n }\n\n getUniqueLayerName(name: string) {\n let suggestedName = name;\n let suffix = 0;\n while (this.getLayerByName(suggestedName) !== undefined) {\n suggestedName = name + ++suffix;\n }\n return suggestedName;\n }\n\n has(layer: Borrowed) {\n return this.layerSet.has(layer);\n }\n\n get renderLayers() {\n const layerManager = this;\n return {\n *[Symbol.iterator]() {\n for (const managedLayer of layerManager.managedLayers) {\n if (managedLayer.layer === null) {\n continue;\n }\n for (const renderLayer of managedLayer.layer.renderLayers) {\n yield renderLayer;\n }\n }\n },\n };\n }\n\n get visibleRenderLayers() {\n const layerManager = this;\n return {\n *[Symbol.iterator]() {\n for (const managedLayer of layerManager.managedLayers) {\n if (managedLayer.layer === null || !managedLayer.visible) {\n continue;\n }\n for (const renderLayer of managedLayer.layer.renderLayers) {\n yield renderLayer;\n }\n }\n },\n };\n }\n\n invokeAction(action: string) {\n const context = new LayerActionContext();\n for (const managedLayer of this.managedLayers) {\n if (managedLayer.layer === null || !managedLayer.visible) {\n continue;\n }\n const userLayer = managedLayer.layer;\n userLayer.handleAction(action, context);\n for (const renderLayer of userLayer.renderLayers) {\n renderLayer.handleAction(action);\n }\n }\n for (const callback of context.callbacks) {\n callback();\n }\n }\n}\n\nexport interface PickState {\n pickedRenderLayer: RenderLayer | null;\n pickedValue: Uint64;\n pickedOffset: number;\n pickedAnnotationLayer: AnnotationLayerState | undefined;\n pickedAnnotationId: string | undefined;\n pickedAnnotationBuffer: ArrayBuffer | undefined;\n pickedAnnotationBufferBaseOffset: number | undefined;\n pickedAnnotationIndex: number | undefined;\n pickedAnnotationCount: number | undefined;\n pickedAnnotationType: AnnotationType | undefined;\n}\n\nexport class MouseSelectionState implements PickState {\n changed = new NullarySignal();\n coordinateSpace: CoordinateSpace = emptyInvalidCoordinateSpace;\n position: Float32Array = kEmptyFloat32Vec;\n unsnappedPosition: Float32Array = kEmptyFloat32Vec;\n active = false;\n displayDimensions: DisplayDimensions | undefined = undefined;\n pickedRenderLayer: RenderLayer | null = null;\n pickedValue = new Uint64(0, 0);\n pickedOffset = 0;\n pickedAnnotationLayer: AnnotationLayerState | undefined = undefined;\n pickedAnnotationId: string | undefined = undefined;\n pickedAnnotationBuffer: ArrayBuffer | undefined = undefined;\n // Base offset into `pickedAnnotationBuffer` of the `pickedAnnotationCount` serialized annotations\n // of `pickedAnnotationType`.\n pickedAnnotationBufferBaseOffset: number | undefined = undefined;\n // Index (out of a total of `pickedAnnotationCount`) of the picked annotation.\n pickedAnnotationIndex: number | undefined = undefined;\n pickedAnnotationCount: number | undefined = undefined;\n pickedAnnotationType: AnnotationType | undefined = undefined;\n pageX: number;\n pageY: number;\n\n private forcerFunction: (() => void) | undefined = undefined;\n\n removeForcer(forcer: () => void) {\n if (forcer === this.forcerFunction) {\n this.forcerFunction = undefined;\n this.setActive(false);\n }\n }\n\n setForcer(forcer: (() => void) | undefined) {\n this.forcerFunction = forcer;\n if (forcer === undefined) {\n this.setActive(false);\n }\n }\n\n updateUnconditionally(): boolean {\n const { forcerFunction } = this;\n if (forcerFunction === undefined) {\n return false;\n }\n forcerFunction();\n return this.active;\n }\n\n setActive(value: boolean) {\n if (this.active !== value || value === true) {\n this.active = value;\n this.changed.dispatch();\n }\n }\n}\n\nexport class LayerSelectedValues extends RefCounted {\n changed = new NullarySignal();\n needsUpdate = true;\n constructor(\n public layerManager: LayerManager,\n public mouseState: MouseSelectionState,\n ) {\n super();\n this.registerDisposer(\n mouseState.changed.add(() => {\n this.handleChange();\n }),\n );\n this.registerDisposer(\n layerManager.layersChanged.add(() => {\n this.handleLayerChange();\n }),\n );\n }\n\n /**\n * This should be called when the layer data may have changed, due to the set of managed layers\n * changing or new data having been received.\n */\n handleLayerChange() {\n if (this.mouseState.active) {\n this.handleChange();\n }\n }\n\n handleChange() {\n this.needsUpdate = true;\n this.changed.dispatch();\n }\n\n update() {\n if (!this.needsUpdate) {\n return;\n }\n this.needsUpdate = false;\n const mouseState = this.mouseState;\n const generation = this.changed.count;\n if (mouseState.active) {\n for (const layer of this.layerManager.managedLayers) {\n const userLayer = layer.layer;\n if (layer.visible && userLayer !== null) {\n const { selectionState } = userLayer;\n userLayer.resetSelectionState(selectionState);\n selectionState.generation = generation;\n userLayer.captureSelectionState(selectionState, mouseState);\n }\n }\n }\n }\n\n get(userLayer: T): T[\"selectionState\"] | undefined {\n this.update();\n const { selectionState } = userLayer;\n if (selectionState.generation !== this.changed.count) return undefined;\n return selectionState;\n }\n\n toJSON() {\n this.update();\n const result: { [key: string]: any } = {};\n for (const layer of this.layerManager.managedLayers) {\n const userLayer = layer.layer;\n if (userLayer) {\n const state = this.get(userLayer);\n if (state !== undefined) {\n result[layer.name] = userLayer.selectionStateToJson(state, true);\n }\n }\n }\n return result;\n }\n}\n\nexport interface PersistentLayerSelectionState {\n layer: UserLayer;\n state: UserLayerSelectionState;\n}\n\nexport interface PersistentViewerSelectionState {\n layers: PersistentLayerSelectionState[];\n coordinateSpace: CoordinateSpace;\n position: Float32Array | undefined;\n}\n\nconst maxSelectionHistorySize = 10;\n\nconst DATA_SELECTION_STATE_DEFAULT_PANEL_LOCATION = {\n ...DEFAULT_SIDE_PANEL_LOCATION,\n minSize: 150,\n row: 1,\n};\n\nconst DATA_SELECTION_STATE_DEFAULT_PANEL_LOCATION_VISIBLE = {\n ...DATA_SELECTION_STATE_DEFAULT_PANEL_LOCATION,\n visible: true,\n};\n\nexport class TrackableDataSelectionState\n extends RefCounted\n implements\n TrackableValueInterface\n{\n changed = new NullarySignal();\n history: PersistentViewerSelectionState[] = [];\n historyIndex = 0;\n location = new TrackableSidePanelLocation(\n DATA_SELECTION_STATE_DEFAULT_PANEL_LOCATION,\n );\n\n constructor(\n public coordinateSpace: WatchableValueInterface,\n public layerSelectedValues: Borrowed,\n ) {\n super();\n this.registerDisposer(\n registerNested((context, pin) => {\n if (pin) return;\n this.capture(true);\n context.registerDisposer(\n layerSelectedValues.changed.add(\n context.registerCancellable(\n throttle(() => this.capture(true), 100, {\n leading: true,\n trailing: true,\n }),\n ),\n ),\n );\n }, this.pin),\n );\n this.pin.changed.add(this.changed.dispatch);\n this.location.changed.add(this.changed.dispatch);\n }\n private value_: PersistentViewerSelectionState | undefined;\n pin = new WatchableValue(true);\n get value() {\n return this.value_;\n }\n\n goBack() {\n const curIndex = this.pin.value ? this.historyIndex : this.history.length;\n if (curIndex > 0) {\n this.historyIndex = curIndex - 1;\n this.value_ = this.history[curIndex - 1];\n this.pin.value = true;\n this.changed.dispatch();\n }\n }\n\n canGoBack() {\n const curIndex = this.pin.value ? this.historyIndex : this.history.length;\n return curIndex > 0;\n }\n\n canGoForward() {\n if (!this.pin.value) return false;\n const curIndex = this.historyIndex;\n return curIndex + 1 < this.history.length;\n }\n\n goForward() {\n if (!this.pin.value) return;\n const curIndex = this.historyIndex;\n if (curIndex + 1 < this.history.length) {\n this.historyIndex = curIndex + 1;\n this.value_ = this.history[curIndex + 1];\n this.changed.dispatch();\n }\n }\n\n set value(value: PersistentViewerSelectionState | undefined) {\n if (value !== this.value_) {\n this.value_ = value;\n if (value !== undefined && this.pin.value) {\n // Add to history\n const { history } = this;\n history.length = Math.min(history.length, this.historyIndex + 1);\n history.push(value);\n if (history.length > maxSelectionHistorySize) {\n history.splice(0, history.length - maxSelectionHistorySize);\n }\n this.historyIndex = history.length - 1;\n }\n this.changed.dispatch();\n }\n }\n\n captureSingleLayerState(\n userLayer: Borrowed,\n capture: (state: T[\"selectionState\"]) => boolean,\n pin: boolean | \"toggle\" = true,\n ) {\n if (pin === false && (!this.location.visible || this.pin.value)) return;\n const state = {} as UserLayerSelectionState;\n userLayer.initializeSelectionState(state);\n if (capture(state)) {\n this.location.visible = true;\n if (pin === true) {\n this.pin.value = true;\n } else if (pin === \"toggle\") {\n this.pin.value = !this.pin.value;\n }\n this.value = {\n layers: [{ layer: userLayer, state }],\n coordinateSpace: this.coordinateSpace.value,\n position: undefined,\n };\n }\n }\n reset() {\n this.location.reset();\n this.pin.value = false;\n this.value = undefined;\n }\n toJSON() {\n // Default panel configuration, not visible: -> undefined\n // Default panel configuration, visible: -> {}\n // Non-default panel configuration, not visible: -> {side: 'left', ..., visible: false}}\n // Non-default panel configuration, visible: -> {side: 'left', ...}\n const { value } = this;\n let obj: any;\n if (this.location.visible) {\n obj = this.location.toJSON(\n DATA_SELECTION_STATE_DEFAULT_PANEL_LOCATION_VISIBLE,\n );\n if (this.pin.value && value !== undefined) {\n const layersJson: any = {};\n for (const layerData of value.layers) {\n const { layer } = layerData;\n let data = layer.selectionStateToJson(layerData.state, false);\n if (Object.keys(data).length === 0) data = undefined;\n layersJson[layerData.layer.managedLayer.name] = data;\n }\n if (value.position !== undefined) {\n obj.position = Array.from(value.position);\n }\n obj.layers = layersJson;\n }\n } else {\n obj = this.location.toJSON(DATA_SELECTION_STATE_DEFAULT_PANEL_LOCATION);\n obj = emptyToUndefined(obj);\n if (obj !== undefined) {\n obj.visible = false;\n }\n }\n return obj;\n }\n select() {\n const { pin } = this;\n this.location.visible = true;\n pin.value = !pin.value;\n if (pin.value) {\n this.capture();\n }\n }\n capture(canRetain = false) {\n const newValue = capturePersistentViewerSelectionState(\n this.layerSelectedValues,\n );\n if (canRetain && newValue === undefined) return;\n this.value = newValue;\n }\n restoreState(obj: unknown) {\n if (obj === undefined) {\n this.pin.value = true;\n this.value = undefined;\n return;\n }\n if (obj === null) {\n // Support for old representation where `null` means visible but unpinned.\n this.pin.value = false;\n this.location.visible = true;\n this.value = undefined;\n return;\n }\n verifyObject(obj);\n // If the object is present, then visible by default.\n this.location.restoreState(\n obj,\n DATA_SELECTION_STATE_DEFAULT_PANEL_LOCATION_VISIBLE,\n );\n const coordinateSpace = this.coordinateSpace.value;\n const position = verifyOptionalObjectProperty(\n obj,\n \"position\",\n (positionObj) =>\n parseFixedLengthArray(\n new Float32Array(coordinateSpace.rank),\n positionObj,\n verifyFiniteFloat,\n ),\n );\n const layers: PersistentLayerSelectionState[] = [];\n verifyOptionalObjectProperty(obj, \"layers\", (layersObj) => {\n verifyObject(layersObj);\n const { layerManager } = this.layerSelectedValues;\n for (const [name, entry] of Object.entries(layersObj)) {\n const managedLayer = layerManager.getLayerByName(name);\n if (managedLayer === undefined) return;\n const layer = managedLayer.layer;\n if (layer === null) return;\n verifyObject(entry);\n const state: UserLayerSelectionState = {} as any;\n layer.initializeSelectionState(state);\n layer.selectionStateFromJson(state, entry);\n layers.push({ layer, state });\n }\n });\n this.pin.value = layers.length > 0 || position !== undefined;\n this.value = { position, coordinateSpace, layers };\n }\n}\n\nexport function capturePersistentViewerSelectionState(\n layerSelectedValues: Borrowed,\n): PersistentViewerSelectionState | undefined {\n const { mouseState } = layerSelectedValues;\n if (!mouseState.active) return undefined;\n const layers: PersistentLayerSelectionState[] = [];\n for (const layer of layerSelectedValues.layerManager.managedLayers) {\n const userLayer = layer.layer;\n if (userLayer === null) continue;\n const state = layerSelectedValues.get(userLayer);\n if (state === undefined) continue;\n const stateCopy = {} as UserLayerSelectionState;\n userLayer.initializeSelectionState(stateCopy);\n userLayer.copySelectionState(stateCopy, state);\n layers.push({\n layer: userLayer,\n state: stateCopy,\n });\n }\n return {\n position: mouseState.position.slice(),\n coordinateSpace: mouseState.coordinateSpace,\n layers,\n };\n}\n\nexport interface LayerView {\n displayDimensionRenderInfo: WatchableDisplayDimensionRenderInfo;\n flushBackendProjectionParameters(): void;\n rpc: RPC;\n rpcId: number;\n}\n\nexport class VisibleLayerInfo<\n View extends LayerView = LayerView,\n AttachmentState = unknown,\n> extends RefCounted {\n messages = new MessageList();\n seenGeneration = -1;\n state: AttachmentState | undefined = undefined;\n constructor(public view: View) {\n super();\n }\n}\n\nlet visibleLayerInfoGeneration = 0;\n\nexport class VisibleRenderLayerTracker<\n View extends LayerView,\n RenderLayerType extends VisibilityTrackedRenderLayer,\n> extends RefCounted {\n /**\n * Maps a layer to the disposer to call when it is no longer visible.\n */\n private visibleLayers_ = new Map>();\n\n private debouncedUpdateVisibleLayers = this.registerCancellable(\n debounce(() => this.updateVisibleLayers(), 0),\n );\n\n constructor(\n public layerManager: LayerManager,\n public renderLayerType: { new (...args: any[]): RenderLayerType },\n public view: View,\n public roles: WatchableSet,\n private layerAdded: (\n layer: RenderLayerType,\n info: VisibleLayerInfo,\n ) => void,\n public visibility: WatchableVisibilityPriority,\n ) {\n super();\n this.registerDisposer(\n layerManager.layersChanged.add(this.debouncedUpdateVisibleLayers),\n );\n this.registerDisposer(roles.changed.add(this.debouncedUpdateVisibleLayers));\n this.updateVisibleLayers();\n }\n\n disposed() {\n this.visibleLayers.forEach((attachment) => attachment.dispose());\n this.visibleLayers.clear();\n super.disposed();\n }\n\n private updateVisibleLayers() {\n const curGeneration = ++visibleLayerInfoGeneration;\n const {\n visibleLayers_: visibleLayers,\n renderLayerType,\n layerAdded,\n roles,\n } = this;\n for (const renderLayer of this.layerManager.readyRenderLayers()) {\n if (\n renderLayer instanceof renderLayerType &&\n roles.has(renderLayer.role)\n ) {\n const typedLayer = renderLayer;\n let info = visibleLayers.get(typedLayer);\n if (info === undefined) {\n info = new VisibleLayerInfo(this.view);\n info.registerDisposer(typedLayer.messages.addChild(info.messages));\n info.registerDisposer(typedLayer.addRef());\n info.registerDisposer(typedLayer.visibility.add(this.visibility));\n visibleLayers.set(typedLayer, info);\n layerAdded(typedLayer, info);\n typedLayer.attach(info);\n }\n info.seenGeneration = curGeneration;\n }\n }\n for (const [renderLayer, info] of visibleLayers) {\n if (info.seenGeneration !== curGeneration) {\n visibleLayers.delete(renderLayer);\n info.dispose();\n }\n }\n }\n\n get visibleLayers() {\n this.debouncedUpdateVisibleLayers.flush();\n return this.visibleLayers_;\n }\n}\n\nexport function makeRenderedPanelVisibleLayerTracker<\n View extends RenderedPanel & LayerView,\n RenderLayerType extends VisibilityTrackedRenderLayer,\n>(\n layerManager: LayerManager,\n renderLayerType: { new (...args: any[]): RenderLayerType },\n roles: WatchableSet,\n panel: View,\n layerAdded?: (layer: RenderLayerType, info: VisibleLayerInfo) => void,\n) {\n return panel.registerDisposer(\n new VisibleRenderLayerTracker(\n layerManager,\n renderLayerType,\n panel,\n roles,\n (layer, info) => {\n info.registerDisposer(\n layer.redrawNeeded.add(() => panel.scheduleRedraw()),\n );\n const { backend } = layer;\n if (backend) {\n backend.rpc!.invoke(RENDERED_VIEW_ADD_LAYER_RPC_ID, {\n layer: backend.rpcId,\n view: panel.rpcId,\n });\n info.registerDisposer(() =>\n backend.rpc!.invoke(RENDERED_VIEW_REMOVE_LAYER_RPC_ID, {\n layer: backend.rpcId,\n view: panel.rpcId,\n }),\n );\n }\n if (layerAdded !== undefined) {\n layerAdded(layer, info);\n }\n panel.scheduleRedraw();\n info.registerDisposer(() => panel.scheduleRedraw());\n },\n panel.visibility,\n ),\n );\n}\n\nexport class SelectedLayerState extends RefCounted implements Trackable {\n changed = new NullarySignal();\n location = new TrackableSidePanelLocation(\n SELECTED_LAYER_SIDE_PANEL_DEFAULT_LOCATION,\n );\n layer_: ManagedUserLayer | undefined;\n\n get layer() {\n return this.layer_;\n }\n\n get visible() {\n return this.location.visible;\n }\n\n toggle(layer: ManagedUserLayer) {\n if (this.layer === layer && this.visible) {\n this.visible = false;\n } else {\n this.layer = layer;\n this.visible = true;\n }\n }\n\n set visible(value: boolean) {\n let existingLayer = this.layer_;\n if (value === true && existingLayer === undefined) {\n // Check if there is a layer\n const { managedLayers } = this.layerManager;\n if (managedLayers.length > 0) {\n existingLayer = this.layer = managedLayers[0];\n } else {\n value = false;\n }\n }\n if (value === true && existingLayer !== undefined) {\n const userLayer = existingLayer.layer;\n if (userLayer === null || userLayer.panels.panels[0].tabs.length === 0) {\n value = false;\n }\n }\n if (this.visible !== value) {\n this.location.visible = value;\n if (!value && existingLayer !== undefined) {\n this.maybeDeleteNewLayer(existingLayer);\n }\n this.changed.dispatch();\n }\n }\n\n private maybeDeleteNewLayer(existingLayer: ManagedUserLayer) {\n if (existingLayer.wasDisposed) return;\n const userLayer = existingLayer.layer;\n if (userLayer !== null && userLayer instanceof NewUserLayer) {\n if (!userLayer.dataSources.some((x) => x.spec.url.length !== 0)) {\n deleteLayer(existingLayer);\n }\n }\n }\n\n private existingLayerDisposer?: () => void;\n\n constructor(public layerManager: Owned) {\n super();\n this.registerDisposer(layerManager);\n this.location.changed.add(() => {\n this.changed.dispatch();\n const userLayer = this.layer?.layer ?? undefined;\n if (userLayer !== undefined) {\n const curLocation = this.location.value;\n if (curLocation.visible) {\n const panel = userLayer.panels.panels[0];\n if (panel.location.value !== curLocation) {\n panel.location.value = curLocation;\n panel.location.locationChanged.dispatch();\n }\n }\n }\n });\n }\n\n set layer(layer: ManagedUserLayer | undefined) {\n if (layer === this.layer_) {\n return;\n }\n const existingLayer = this.layer_;\n if (existingLayer !== undefined) {\n this.existingLayerDisposer!();\n this.existingLayerDisposer = undefined;\n this.maybeDeleteNewLayer(existingLayer);\n }\n this.layer_ = layer;\n if (layer !== undefined) {\n const layerDisposed = () => {\n this.layer_ = undefined;\n this.visible = false;\n this.existingLayerDisposer = undefined;\n this.changed.dispatch();\n };\n layer.registerDisposer(layerDisposed);\n const layerChangedDisposer = layer.specificationChanged.add(() => {\n this.changed.dispatch();\n });\n this.existingLayerDisposer = () => {\n const userLayer = layer.layer;\n if (userLayer !== null) {\n const tool = userLayer.tool.value;\n if (tool !== undefined) {\n tool.deactivate();\n }\n }\n layer.unregisterDisposer(layerDisposed);\n layerChangedDisposer();\n };\n } else {\n this.location.visible = false;\n }\n this.changed.dispatch();\n }\n\n toJSON() {\n const obj: any = this.location.toJSON();\n if (this.layer !== undefined) {\n obj.layer = this.layer.name;\n }\n return emptyToUndefined(obj);\n }\n\n restoreState(obj: any) {\n if (obj === undefined) {\n this.reset();\n return;\n }\n verifyObject(obj);\n this.location.restoreState(obj);\n const layerName = verifyObjectProperty(obj, \"layer\", verifyOptionalString);\n const layer =\n layerName !== undefined\n ? this.layerManager.getLayerByName(layerName)\n : undefined;\n if (layer === undefined) {\n this.visible = false;\n }\n this.layer = layer;\n }\n\n reset() {\n this.location.reset();\n this.layer = undefined;\n }\n}\n\nexport class LayerReference extends RefCounted implements Trackable {\n private layerName_: string | undefined;\n private layer_: ManagedUserLayer | undefined;\n changed = new NullarySignal();\n constructor(\n public layerManager: Owned,\n public filter: (layer: ManagedUserLayer) => boolean,\n ) {\n super();\n this.registerDisposer(layerManager);\n this.registerDisposer(\n layerManager.specificationChanged.add(() => {\n const { layer_ } = this;\n if (layer_ !== undefined) {\n if (!this.layerManager.layerSet.has(layer_) || !this.filter(layer_)) {\n this.layer_ = undefined;\n this.layerName_ = undefined;\n this.changed.dispatch();\n } else {\n const { name } = layer_;\n if (name !== this.layerName_) {\n this.layerName_ = name;\n this.changed.dispatch();\n }\n }\n }\n }),\n );\n }\n\n get layer() {\n return this.layer_;\n }\n\n get layerName() {\n return this.layerName_;\n }\n\n set layer(value: ManagedUserLayer | undefined) {\n if (this.layer_ === value) {\n return;\n }\n if (\n value !== undefined &&\n this.layerManager.layerSet.has(value) &&\n this.filter(value)\n ) {\n this.layer_ = value;\n this.layerName_ = value.name;\n } else {\n this.layer_ = undefined;\n this.layerName_ = undefined;\n }\n this.changed.dispatch();\n }\n\n set layerName(value: string | undefined) {\n if (value === this.layerName_) {\n return;\n }\n this.layer_ = undefined;\n this.layerName_ = value;\n this.changed.dispatch();\n this.validate();\n }\n\n private validate = debounce(() => {\n const { layerName_ } = this;\n if (layerName_ !== undefined) {\n const layer = this.layerManager.getLayerByName(layerName_);\n if (layer !== undefined && this.filter(layer)) {\n this.layer_ = layer;\n this.changed.dispatch();\n } else {\n this.layer_ = undefined;\n this.layerName_ = undefined;\n this.changed.dispatch();\n }\n }\n }, 0);\n\n restoreState(obj: any) {\n const layerName = verifyOptionalString(obj);\n this.layerName = layerName;\n }\n\n toJSON() {\n const { layer_ } = this;\n if (layer_ !== undefined) {\n return layer_.name;\n }\n return this.layerName_;\n }\n\n reset() {\n this.layerName_ = undefined;\n this.layer_ = undefined;\n this.changed.dispatch();\n }\n}\n\n// Group of layers that share a set of properties, e.g. visible segment set.\nexport class LinkedLayerGroup extends RefCounted implements Trackable {\n // Only valid if `root_ == this.layer`.\n private linkedLayers_ = new Set();\n private root_: UserLayer;\n changed = new NullarySignal();\n linkedLayersChanged = new NullarySignal();\n readonly root: WatchableValueInterface;\n\n get linkedLayers(): ReadonlySet {\n return this.linkedLayers_;\n }\n\n get rootGroup(): LinkedLayerGroup {\n return this.getGroup(this.root.value);\n }\n\n constructor(\n public layerManager: LayerManager,\n public layer: UserLayer,\n public predicate: (layer: UserLayer) => boolean,\n public getGroup: (layer: UserLayer) => LinkedLayerGroup,\n ) {\n super();\n this.root_ = layer;\n const self = this;\n this.root = {\n get value() {\n return self.root_;\n },\n changed: self.changed,\n };\n }\n\n reset() {\n this.isolate();\n }\n\n restoreState(obj: unknown) {\n if (obj === undefined) return;\n const name = verifyString(obj);\n this.linkByName(name);\n }\n\n toJSON() {\n const {\n root: { value: root },\n } = this;\n if (root === this.layer) return undefined;\n return root.managedLayer.name;\n }\n\n isolate(notifyChanged = true) {\n const { getGroup, layer, root_: root } = this;\n if (root === layer) {\n const { linkedLayers_ } = this;\n if (linkedLayers_.size !== 0) {\n for (const otherLayer of linkedLayers_) {\n const otherGroup = getGroup(otherLayer);\n otherGroup.root_ = otherLayer;\n otherGroup.changed.dispatch();\n }\n linkedLayers_.clear();\n this.linkedLayersChanged.dispatch();\n }\n return;\n }\n const rootGroup = getGroup(root);\n rootGroup.linkedLayers_.delete(layer);\n rootGroup.linkedLayersChanged.dispatch();\n this.root_ = layer;\n if (notifyChanged) {\n this.changed.dispatch();\n }\n }\n\n linkByName(otherLayerName: string) {\n const { layer } = this;\n const { managedLayer } = layer;\n const { layerManager } = this;\n const otherLayer = layerManager.getLayerByName(otherLayerName);\n if (otherLayer === undefined) return;\n if (otherLayer === managedLayer) return;\n const otherUserLayer = otherLayer.layer;\n if (otherUserLayer === null) return;\n if (!this.predicate(otherUserLayer)) return;\n this.linkToLayer(otherUserLayer);\n }\n\n linkToLayer(otherUserLayer: UserLayer) {\n if (otherUserLayer === this.layer) return;\n if (this.root_ === otherUserLayer) return;\n if (this.root_ !== this.layer) {\n this.isolate(/*notifyChanged=*/ false);\n }\n const { getGroup } = this;\n const newRoot = getGroup(otherUserLayer).root_;\n if (newRoot === this.layer) return;\n const rootGroup = getGroup(newRoot);\n rootGroup.linkedLayers_.add(this.layer);\n rootGroup.linkedLayersChanged.dispatch();\n this.root_ = newRoot;\n this.changed.dispatch();\n }\n\n disposed() {\n this.isolate(/*notifyChanged=*/ false);\n }\n}\n\nfunction initializeLayerFromSpecNoRestoreState(\n managedLayer: ManagedUserLayer,\n spec: any,\n) {\n const layerType = verifyOptionalObjectProperty(\n spec,\n \"type\",\n verifyString,\n \"auto\",\n );\n managedLayer.archived = verifyOptionalObjectProperty(\n spec,\n \"archived\",\n verifyBoolean,\n false,\n );\n if (!managedLayer.archived) {\n managedLayer.visible = verifyOptionalObjectProperty(\n spec,\n \"visible\",\n verifyBoolean,\n true,\n );\n } else {\n managedLayer.visible = false;\n }\n const layerConstructor = layerTypes.get(layerType) || NewUserLayer;\n managedLayer.layer = new layerConstructor(managedLayer);\n return spec;\n}\n\nfunction completeUserLayerInitialization(\n managedLayer: Borrowed,\n spec: any,\n) {\n try {\n const userLayer = managedLayer.layer;\n if (userLayer === null) return;\n userLayer.restoreState(spec);\n userLayer.initializationDone();\n } catch (e) {\n deleteLayer(managedLayer);\n throw e;\n }\n}\n\nexport function initializeLayerFromSpec(\n managedLayer: Borrowed,\n spec: any,\n) {\n try {\n verifyObject(spec);\n initializeLayerFromSpecNoRestoreState(managedLayer, spec);\n completeUserLayerInitialization(managedLayer, spec);\n } catch (e) {\n deleteLayer(managedLayer);\n throw e;\n }\n}\n\nexport function initializeLayerFromSpecShowErrorStatus(\n managedLayer: Borrowed,\n spec: any,\n) {\n try {\n initializeLayerFromSpec(managedLayer, spec);\n } catch (e) {\n const msg = new StatusMessage();\n msg.setErrorMessage(e instanceof Error ? e.message : \"\" + e);\n }\n}\n\nexport function makeLayer(\n manager: LayerListSpecification,\n name: string,\n spec: any,\n): ManagedUserLayer {\n const managedLayer = new ManagedUserLayer(name, manager);\n initializeLayerFromSpec(managedLayer, spec);\n return managedLayer;\n}\n\nexport abstract class LayerListSpecification extends RefCounted {\n changed = new NullarySignal();\n\n abstract rpc: RPC;\n\n abstract dataSourceProviderRegistry: Borrowed;\n abstract layerManager: Borrowed;\n abstract chunkManager: Borrowed;\n abstract layerSelectedValues: Borrowed;\n\n abstract readonly root: TopLevelLayerListSpecification;\n\n abstract add(\n layer: Owned,\n index?: number | undefined,\n ): void;\n\n abstract rootLayers: Borrowed;\n}\n\nexport class TopLevelLayerListSpecification extends LayerListSpecification {\n get rpc() {\n return this.chunkManager.rpc!;\n }\n\n get root() {\n return this;\n }\n\n coordinateSpaceCombiner = new CoordinateSpaceCombiner(\n this.coordinateSpace,\n isGlobalDimension,\n );\n subsets = new Set();\n\n layerSelectedValues = this.selectionState.layerSelectedValues;\n\n constructor(\n public display: DisplayContext,\n public dataSourceProviderRegistry: DataSourceProviderRegistry,\n public layerManager: LayerManager,\n public chunkManager: ChunkManager,\n public selectionState: Borrowed,\n public selectedLayer: Borrowed,\n public coordinateSpace: WatchableValueInterface,\n public globalPosition: Borrowed,\n public toolBinder: Borrowed,\n ) {\n super();\n this.registerDisposer(\n layerManager.layersChanged.add(this.changed.dispatch),\n );\n this.registerDisposer(\n layerManager.specificationChanged.add(this.changed.dispatch),\n );\n }\n\n reset() {\n this.layerManager.clear();\n }\n\n restoreState(x: any) {\n this.layerManager.clear();\n let layerSpecs: any[];\n if (!Array.isArray(x)) {\n verifyObject(x);\n layerSpecs = Object.entries(x).map(([name, layerSpec]) => {\n if (typeof layerSpec === \"string\") {\n return { name, source: layerSpec };\n }\n verifyObject(layerSpec);\n return { ...(layerSpec as any), name };\n });\n } else {\n layerSpecs = x;\n }\n const layersToRestore: { managedLayer: ManagedUserLayer; spec: any }[] = [];\n for (const layerSpec of layerSpecs) {\n verifyObject(layerSpec);\n const name = this.layerManager.getUniqueLayerName(\n verifyObjectProperty(layerSpec, \"name\", verifyString),\n );\n const managedLayer = new ManagedUserLayer(name, this);\n try {\n initializeLayerFromSpecNoRestoreState(managedLayer, layerSpec);\n this.layerManager.addManagedLayer(managedLayer);\n layersToRestore.push({ managedLayer, spec: layerSpec });\n } catch (e) {\n managedLayer.dispose();\n const msg = new StatusMessage();\n msg.setErrorMessage(\n `Error creating layer ${JSON.stringify(name)}: ` +\n (e instanceof Error)\n ? e.message\n : \"\" + e,\n );\n }\n }\n for (const { managedLayer, spec } of layersToRestore) {\n try {\n completeUserLayerInitialization(managedLayer, spec);\n } catch (e) {\n const msg = new StatusMessage();\n msg.setErrorMessage(\n `Error creating layer ${JSON.stringify(name)}: ` +\n (e instanceof Error)\n ? e.message\n : \"\" + e,\n );\n }\n }\n }\n\n add(layer: ManagedUserLayer, index?: number | undefined) {\n if (this.layerManager.managedLayers.indexOf(layer) === -1) {\n layer.name = this.layerManager.getUniqueLayerName(layer.name);\n }\n this.layerManager.addManagedLayer(layer, index);\n }\n\n toJSON() {\n const result = [];\n let numResults = 0;\n for (const managedLayer of this.layerManager.managedLayers) {\n const layerJson = managedLayer.toJSON();\n // A `null` layer specification is used to indicate a transient drag target, and should not be\n // serialized.\n if (layerJson != null) {\n result.push(layerJson);\n ++numResults;\n }\n }\n if (numResults === 0) {\n return undefined;\n }\n return result;\n }\n\n get rootLayers() {\n return this.layerManager;\n }\n}\n\n/**\n * Class for specifying a subset of a TopLevelLayerListsSpecification.\n */\nexport class LayerSubsetSpecification extends LayerListSpecification {\n changed = new NullarySignal();\n get rpc() {\n return this.master.rpc;\n }\n get dataSourceProviderRegistry() {\n return this.master.dataSourceProviderRegistry;\n }\n get chunkManager() {\n return this.master.chunkManager;\n }\n get layerSelectedValues() {\n return this.master.layerSelectedValues;\n }\n\n get root() {\n return this.master;\n }\n\n layerManager = this.registerDisposer(new LayerManager());\n\n constructor(public master: Owned) {\n super();\n this.registerDisposer(master);\n const { layerManager } = this;\n this.registerDisposer(\n layerManager.layersChanged.add(this.changed.dispatch),\n );\n this.registerDisposer(\n layerManager.specificationChanged.add(this.changed.dispatch),\n );\n master.subsets.add(this);\n }\n\n disposed() {\n super.disposed();\n this.master.subsets.delete(this);\n }\n\n reset() {\n this.layerManager.clear();\n }\n\n restoreState(x: any) {\n const masterLayerManager = this.master.layerManager;\n const layers: ManagedUserLayer[] = [];\n for (const name of new Set(parseArray(x, verifyString))) {\n const layer = masterLayerManager.getLayerByName(name);\n if (layer === undefined) {\n throw new Error(\n `Undefined layer referenced in subset specification: ${JSON.stringify(\n name,\n )}`,\n );\n }\n if (layer.archived) continue;\n layers.push(layer);\n }\n this.layerManager.clear();\n for (const layer of layers) {\n this.layerManager.addManagedLayer(layer.addRef());\n }\n }\n\n toJSON() {\n return this.layerManager.managedLayers.map((x) => x.name);\n }\n\n add(layer: ManagedUserLayer, index?: number | undefined) {\n if (this.master.layerManager.managedLayers.indexOf(layer) === -1) {\n layer.name = this.master.layerManager.getUniqueLayerName(layer.name);\n this.master.layerManager.addManagedLayer(layer.addRef());\n }\n this.layerManager.addManagedLayer(layer, index);\n }\n\n get rootLayers() {\n return this.master.rootLayers;\n }\n}\n\nexport type UserLayerConstructor =\n typeof UserLayer & AnyConstructor;\n\nexport const layerTypes = new Map();\nconst volumeLayerTypes = new Map();\nexport interface LayerTypeGuess {\n // Layer constructor\n layerConstructor: UserLayerConstructor;\n // Priority of the guess. Higher values take precedence.\n priority: number;\n}\nexport type LayerTypeDetector = (\n subsource: DataSubsource,\n) => LayerTypeGuess | undefined;\nconst layerTypeDetectors: LayerTypeDetector[] = [\n (subsource) => {\n const { volume } = subsource;\n if (volume === undefined) return undefined;\n const layerConstructor = volumeLayerTypes.get(volume.volumeType);\n if (layerConstructor === undefined) return undefined;\n return { layerConstructor, priority: 0 };\n },\n];\n\nexport function registerLayerType(\n layerConstructor: UserLayerConstructor,\n name: string = layerConstructor.type,\n) {\n layerTypes.set(name, layerConstructor);\n}\n\nexport function registerLayerTypeDetector(detector: LayerTypeDetector) {\n layerTypeDetectors.push(detector);\n}\n\nexport function registerVolumeLayerType(\n volumeType: VolumeType,\n layerConstructor: UserLayerConstructor,\n) {\n volumeLayerTypes.set(volumeType, layerConstructor);\n}\n\nexport function changeLayerType(\n managedLayer: Borrowed,\n layerConstructor: typeof UserLayer,\n) {\n const userLayer = managedLayer.layer;\n if (userLayer === null) return;\n const spec = userLayer.toJSON();\n const newUserLayer = new layerConstructor(managedLayer);\n newUserLayer.restoreState(spec);\n newUserLayer.initializationDone();\n managedLayer.layer = newUserLayer;\n}\n\nexport function changeLayerName(\n managedLayer: Borrowed,\n newName: string,\n): boolean {\n if (newName !== managedLayer.name) {\n newName =\n managedLayer.manager.root.layerManager.getUniqueLayerName(newName);\n managedLayer.name = newName;\n managedLayer.layerChanged.dispatch();\n return true;\n }\n return false;\n}\n\nexport function deleteLayer(managedLayer: Borrowed) {\n if (managedLayer.wasDisposed) return;\n for (const layerManager of managedLayer.containers) {\n layerManager.removeManagedLayer(managedLayer);\n }\n}\n\nfunction getMaxPriorityGuess(\n a: LayerTypeGuess | undefined,\n b: LayerTypeGuess | undefined,\n) {\n if (a === undefined) return b;\n if (b === undefined) return a;\n return a.priority < b.priority ? b : a;\n}\n\nexport function detectLayerTypeFromDataSubsource(\n subsource: DataSubsource,\n): LayerTypeGuess | undefined {\n let bestGuess: LayerTypeGuess | undefined;\n for (const detector of layerTypeDetectors) {\n bestGuess = getMaxPriorityGuess(bestGuess, detector(subsource));\n }\n const { volume } = subsource;\n if (volume !== undefined) {\n const layerConstructor = volumeLayerTypes.get(volume.volumeType);\n if (layerConstructor !== undefined) {\n bestGuess = getMaxPriorityGuess(bestGuess, {\n layerConstructor,\n priority: 0,\n });\n }\n }\n return bestGuess;\n}\n\nexport function detectLayerType(\n userLayer: UserLayer,\n): UserLayerConstructor | undefined {\n let guess: LayerTypeGuess | undefined;\n for (const dataSource of userLayer.dataSources) {\n const { loadState } = dataSource;\n if (loadState === undefined || loadState.error !== undefined) continue;\n for (const loadedSubsource of loadState.subsources) {\n const { subsourceEntry } = loadedSubsource;\n const { subsource } = subsourceEntry;\n if (!loadedSubsource.enabled) continue;\n guess = getMaxPriorityGuess(\n guess,\n detectLayerTypeFromDataSubsource(subsource),\n );\n }\n }\n return guess?.layerConstructor;\n}\n\nfunction detectLayerTypeFromSubsources(\n subsources: Iterable,\n): LayerTypeGuess | undefined {\n let guess: LayerTypeGuess | undefined;\n for (const loadedSubsource of subsources) {\n const { subsourceEntry } = loadedSubsource;\n const { subsource } = subsourceEntry;\n guess = getMaxPriorityGuess(\n guess,\n detectLayerTypeFromDataSubsource(subsource),\n );\n }\n return guess;\n}\n\n/**\n * Special UserLayer type used when creating a new layer in the UI.\n */\nexport class NewUserLayer extends UserLayer {\n static type = \"new\";\n static typeAbbreviation = \"new\";\n detectedLayerConstructor: UserLayerConstructor | undefined;\n\n activateDataSubsources(subsources: Iterable) {\n this.detectedLayerConstructor =\n detectLayerTypeFromSubsources(subsources)?.layerConstructor;\n }\n}\n\n/**\n * Special UserLayer type that automatically changes to the appropriate layer type.\n */\nexport class AutoUserLayer extends UserLayer {\n static type = \"auto\";\n static typeAbbreviation = \"auto\";\n\n activateDataSubsources(subsources: Iterable) {\n const layerConstructor =\n detectLayerTypeFromSubsources(subsources)?.layerConstructor;\n if (layerConstructor !== undefined) {\n changeLayerType(this.managedLayer, layerConstructor);\n }\n }\n}\n\nexport function addNewLayer(\n manager: Borrowed,\n selectedLayer: Borrowed,\n) {\n const layer = makeLayer(manager, \"new layer\", { type: \"new\" });\n manager.add(layer);\n selectedLayer.layer = layer;\n selectedLayer.visible = true;\n}\n\nregisterLayerType(NewUserLayer);\nregisterLayerType(AutoUserLayer);\n","export const SELECTED_ALPHA_JSON_KEY = \"selectedAlpha\";\nexport const NOT_SELECTED_ALPHA_JSON_KEY = \"notSelectedAlpha\";\nexport const OBJECT_ALPHA_JSON_KEY = \"objectAlpha\";\nexport const SATURATION_JSON_KEY = \"saturation\";\nexport const HOVER_HIGHLIGHT_JSON_KEY = \"hoverHighlight\";\nexport const HIDE_SEGMENT_ZERO_JSON_KEY = \"hideSegmentZero\";\nexport const BASE_SEGMENT_COLORING_JSON_KEY = \"baseSegmentColoring\";\nexport const IGNORE_NULL_VISIBLE_SET_JSON_KEY = \"ignoreNullVisibleSet\";\nexport const MESH_JSON_KEY = \"mesh\";\nexport const SKELETONS_JSON_KEY = \"skeletons\";\nexport const SEGMENTS_JSON_KEY = \"segments\";\nexport const EQUIVALENCES_JSON_KEY = \"equivalences\";\nexport const COLOR_SEED_JSON_KEY = \"colorSeed\";\nexport const SEGMENT_STATED_COLORS_JSON_KEY = \"segmentColors\";\nexport const MESH_RENDER_SCALE_JSON_KEY = \"meshRenderScale\";\nexport const CROSS_SECTION_RENDER_SCALE_JSON_KEY = \"crossSectionRenderScale\";\nexport const SKELETON_RENDERING_JSON_KEY = \"skeletonRendering\";\nexport const SKELETON_SHADER_JSON_KEY = \"skeletonShader\";\nexport const SEGMENT_QUERY_JSON_KEY = \"segmentQuery\";\nexport const MESH_SILHOUETTE_RENDERING_JSON_KEY = \"meshSilhouetteRendering\";\nexport const LINKED_SEGMENTATION_GROUP_JSON_KEY = \"linkedSegmentationGroup\";\nexport const LINKED_SEGMENTATION_COLOR_GROUP_JSON_KEY =\n \"linkedSegmentationColorGroup\";\nexport const SEGMENT_DEFAULT_COLOR_JSON_KEY = \"segmentDefaultColor\";\nexport const ANCHOR_SEGMENT_JSON_KEY = \"anchorSegment\";\nexport const SKELETON_RENDERING_SHADER_CONTROL_TOOL_ID =\n \"skeletonShaderControl\";\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/layer_control.css\";\n\nimport type { DisplayContext } from \"#src/display_context.js\";\nimport type { UserLayer, UserLayerConstructor } from \"#src/layer/index.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport type { ToolActivation } from \"#src/ui/tool.js\";\nimport {\n LayerTool,\n makeToolActivationStatusMessageWithHeader,\n registerTool,\n ToolBindingWidget,\n} from \"#src/ui/tool.js\";\nimport type { RefCounted } from \"#src/util/disposable.js\";\nimport { WatchableVisibilityPriority } from \"#src/visibility_priority/frontend.js\";\nimport { DependentViewWidget } from \"#src/widget/dependent_view_widget.js\";\n\nexport interface LayerControlLabelOptions<\n LayerType extends UserLayer = UserLayer,\n> {\n label: string;\n title?: string;\n toolDescription?: string;\n toolJson: any;\n isValid?: (layer: LayerType) => WatchableValueInterface;\n}\n\nexport interface LayerControlFactory<\n LayerType extends UserLayer,\n ControlType = unknown,\n> {\n makeControl: (\n layer: LayerType,\n context: RefCounted,\n options: {\n labelContainer: HTMLElement;\n labelTextContainer: HTMLElement;\n display: DisplayContext;\n visibility: WatchableVisibilityPriority;\n },\n ) => {\n control: ControlType;\n controlElement: HTMLElement;\n };\n activateTool: (\n activation: ToolActivation>,\n control: ControlType,\n ) => void;\n}\n\nexport interface LayerControlDefinition<\n LayerType extends UserLayer,\n ControlType = unknown,\n> extends LayerControlLabelOptions,\n LayerControlFactory {}\n\nfunction makeControl(\n context: RefCounted,\n layer: LayerType,\n options: LayerControlDefinition,\n visibility: WatchableVisibilityPriority,\n) {\n const controlContainer = document.createElement(\"label\");\n controlContainer.classList.add(\"neuroglancer-layer-control-container\");\n const labelContainer = document.createElement(\"div\");\n labelContainer.classList.add(\"neuroglancer-layer-control-label-container\");\n const label = document.createElement(\"div\");\n label.classList.add(\"neuroglancer-layer-control-label\");\n labelContainer.appendChild(label);\n const labelTextContainer = document.createElement(\"div\");\n labelTextContainer.classList.add(\n \"neuroglancer-layer-control-label-text-container\",\n );\n labelTextContainer.appendChild(document.createTextNode(options.label));\n label.appendChild(labelTextContainer);\n if (options.title) {\n label.title = options.title;\n }\n controlContainer.appendChild(labelContainer);\n\n const { control, controlElement } = options.makeControl(layer, context, {\n labelContainer,\n labelTextContainer,\n display: layer.manager.root.display,\n visibility,\n });\n controlElement.classList.add(\"neuroglancer-layer-control-control\");\n controlContainer.appendChild(controlElement);\n return {\n controlContainer,\n label,\n labelContainer,\n labelTextContainer,\n control,\n };\n}\n\nexport class LayerControlTool<\n LayerType extends UserLayer = UserLayer,\n> extends LayerTool {\n constructor(\n layer: LayerType,\n public options: LayerControlDefinition,\n ) {\n super(layer);\n }\n activate(activation: ToolActivation) {\n const { options } = this;\n const { layer } = this;\n const { isValid } = options;\n if (isValid !== undefined && !isValid(layer).value) return;\n const { header, body } =\n makeToolActivationStatusMessageWithHeader(activation);\n const { controlContainer, control, labelContainer } = makeControl(\n activation,\n layer,\n options,\n new WatchableVisibilityPriority(WatchableVisibilityPriority.VISIBLE),\n );\n header.appendChild(labelContainer);\n body.appendChild(controlContainer);\n options.activateTool(activation, control);\n }\n get description() {\n const { options } = this;\n return options.toolDescription ?? options.label;\n }\n toJSON() {\n return this.options.toolJson;\n }\n}\n\nfunction makeLayerControlToOptionsTab(\n context: RefCounted,\n layer: LayerType,\n options: LayerControlDefinition,\n visibility: WatchableVisibilityPriority,\n): HTMLElement {\n const { controlContainer, label } = makeControl(\n context,\n layer,\n options,\n visibility,\n );\n controlContainer.classList.add(\n \"neuroglancer-layer-options-control-container\",\n );\n label.prepend(\n context.registerDisposer(\n new ToolBindingWidget(layer.toolBinder, options.toolJson),\n ).element,\n );\n return controlContainer;\n}\n\nexport function addLayerControlToOptionsTab(\n context: RefCounted,\n layer: LayerType,\n visibility: WatchableVisibilityPriority,\n options: LayerControlDefinition,\n): HTMLElement {\n const { isValid } = options;\n if (isValid === undefined) {\n return makeLayerControlToOptionsTab(context, layer, options, visibility);\n }\n return context.registerDisposer(\n new DependentViewWidget(\n isValid(layer),\n (valid, parent, context) => {\n if (!valid) return;\n parent.appendChild(\n makeLayerControlToOptionsTab(context, layer, options, visibility),\n );\n },\n visibility,\n ),\n ).element;\n}\n\nexport function registerLayerControl(\n layerType: UserLayerConstructor,\n options: LayerControlDefinition,\n) {\n const { toolJson } = options;\n const toolId = typeof toolJson === \"string\" ? toolJson : toolJson.type;\n registerTool(\n layerType,\n toolId,\n (layer) => new LayerControlTool(layer, options),\n );\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { UserLayer } from \"#src/layer/index.js\";\nimport { TrackableBooleanCheckbox } from \"#src/trackable_boolean.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport type { LayerControlFactory } from \"#src/widget/layer_control.js\";\n\nexport function checkboxLayerControl(\n getter: (layer: LayerType) => WatchableValueInterface,\n): LayerControlFactory {\n return {\n makeControl: (layer, context) => {\n const value = getter(layer);\n const control = context.registerDisposer(\n new TrackableBooleanCheckbox(value),\n );\n return { control, controlElement: control.element };\n },\n activateTool: (_activation, control) => {\n control.model.value = !control.model.value;\n },\n };\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { UserLayer } from \"#src/layer/index.js\";\nimport type { ActionEvent } from \"#src/util/event_action_map.js\";\nimport { EventActionMap } from \"#src/util/event_action_map.js\";\nimport type { TrackableEnum } from \"#src/util/trackable_enum.js\";\nimport { EnumSelectWidget } from \"#src/widget/enum_widget.js\";\nimport type { LayerControlFactory } from \"#src/widget/layer_control.js\";\n\nconst TOOL_INPUT_EVENT_MAP = EventActionMap.fromObject({\n \"at:shift+wheel\": { action: \"adjust-via-wheel\" },\n});\n\nexport function enumLayerControl(\n getter: (layer: LayerType) => TrackableEnum,\n): LayerControlFactory> {\n return {\n makeControl: (layer, context) => {\n const value = getter(layer);\n const control = context.registerDisposer(new EnumSelectWidget(value));\n return { control, controlElement: control.element };\n },\n activateTool: (activation, control) => {\n activation.bindInputEventMap(TOOL_INPUT_EVENT_MAP);\n activation.bindAction(\n \"adjust-via-wheel\",\n (event: ActionEvent) => {\n event.stopPropagation();\n event.preventDefault();\n control.adjustViaWheel(event.detail);\n },\n );\n },\n };\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/range.css\";\n\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { removeFromParent } from \"#src/util/dom.js\";\n\nexport interface RangeWidgetOptions {\n min?: number;\n max?: number;\n step?: number;\n}\n\nexport class RangeWidget extends RefCounted {\n element = document.createElement(\"label\");\n inputElement = document.createElement(\"input\");\n numericInputElement = document.createElement(\"input\");\n\n constructor(\n public value: WatchableValueInterface,\n { min = 0, max = 1, step = 0.01 }: RangeWidgetOptions = {},\n ) {\n super();\n const { element, inputElement, numericInputElement } = this;\n element.className = \"range-slider\";\n const initInputElement = (el: HTMLInputElement) => {\n el.min = \"\" + min;\n el.max = \"\" + max;\n el.step = \"\" + step;\n el.valueAsNumber = this.value.value;\n this.registerEventListener(el, \"change\", () =>\n this.inputValueChanged(el),\n );\n this.registerEventListener(el, \"input\", () => this.inputValueChanged(el));\n this.registerEventListener(el, \"wheel\", (event: WheelEvent) => {\n this.adjustViaWheel(el, event);\n });\n };\n inputElement.type = \"range\";\n initInputElement(inputElement);\n numericInputElement.type = \"number\";\n const maxNumberWidth = Math.max(\n min.toString().length,\n max.toString().length,\n Math.min(max, min + step).toString().length,\n Math.max(min, max - step).toString().length,\n );\n numericInputElement.style.width = maxNumberWidth + 2 + \"ch\";\n initInputElement(numericInputElement);\n element.appendChild(inputElement);\n element.appendChild(numericInputElement);\n value.changed.add(() => {\n this.inputElement.valueAsNumber = this.value.value;\n this.numericInputElement.valueAsNumber = this.value.value;\n });\n }\n\n private inputValueChanged(element: HTMLInputElement) {\n this.value.value = element.valueAsNumber;\n }\n\n adjustViaWheel(element: HTMLInputElement, event: WheelEvent) {\n const el = this.inputElement;\n const { deltaY } = event;\n if (deltaY > 0) {\n el.stepUp();\n this.inputValueChanged(element);\n } else if (deltaY < 0) {\n el.stepDown();\n this.inputValueChanged(element);\n }\n }\n\n disposed() {\n removeFromParent(this.element);\n super.disposed();\n }\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { UserLayer } from \"#src/layer/index.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport type { ActionEvent } from \"#src/util/event_action_map.js\";\nimport { EventActionMap } from \"#src/util/event_action_map.js\";\nimport type { LayerControlFactory } from \"#src/widget/layer_control.js\";\nimport type { RangeWidgetOptions } from \"#src/widget/range.js\";\nimport { RangeWidget } from \"#src/widget/range.js\";\n\nconst TOOL_INPUT_EVENT_MAP = EventActionMap.fromObject({\n \"at:shift+wheel\": { action: \"adjust-via-wheel\" },\n});\n\nexport function rangeLayerControl(\n getter: (layer: LayerType) => {\n value: WatchableValueInterface;\n options?: RangeWidgetOptions;\n },\n): LayerControlFactory {\n return {\n makeControl: (layer, context) => {\n const { value, options } = getter(layer);\n const control = context.registerDisposer(new RangeWidget(value, options));\n return { control, controlElement: control.element };\n },\n activateTool: (activation, control) => {\n activation.bindInputEventMap(TOOL_INPUT_EVENT_MAP);\n activation.bindAction(\n \"adjust-via-wheel\",\n (event: ActionEvent) => {\n event.stopPropagation();\n event.preventDefault();\n control.adjustViaWheel(control.inputElement, event.detail);\n },\n );\n },\n };\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport function numberToStringFixed(v: number, maxDigits: number) {\n let s = \"\";\n for (let digits = 0; digits <= maxDigits; ++digits) {\n s = v.toFixed(digits);\n if (parseFloat(s) === v) {\n break;\n }\n }\n return s;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/render_scale_widget.css\";\n\nimport { debounce, throttle } from \"lodash-es\";\nimport type { UserLayer } from \"#src/layer/index.js\";\nimport type { RenderScaleHistogram } from \"#src/render_scale_statistics.js\";\nimport {\n getRenderScaleFromHistogramOffset,\n getRenderScaleHistogramOffset,\n numRenderScaleHistogramBins,\n renderScaleHistogramBinSize,\n renderScaleHistogramOrigin,\n} from \"#src/render_scale_statistics.js\";\nimport type { TrackableValueInterface } from \"#src/trackable_value.js\";\nimport { WatchableValue } from \"#src/trackable_value.js\";\nimport { serializeColor } from \"#src/util/color.js\";\nimport { hsvToRgb } from \"#src/util/colorspace.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type { ActionEvent } from \"#src/util/event_action_map.js\";\nimport {\n EventActionMap,\n registerActionListener,\n} from \"#src/util/event_action_map.js\";\nimport { vec3 } from \"#src/util/geom.js\";\nimport { clampToInterval } from \"#src/util/lerp.js\";\nimport { MouseEventBinder } from \"#src/util/mouse_bindings.js\";\nimport { numberToStringFixed } from \"#src/util/number_to_string.js\";\nimport { formatScaleWithUnitAsString } from \"#src/util/si_units.js\";\nimport type { LayerControlFactory } from \"#src/widget/layer_control.js\";\n\nconst updateInterval = 200;\n\nconst inputEventMap = EventActionMap.fromObject({\n mousedown0: { action: \"set\" },\n wheel: { action: \"adjust-via-wheel\" },\n dblclick0: { action: \"reset\" },\n});\n\nfunction formatPixelNumber(x: number) {\n if (x < 1 || x > 1024) {\n const exponent = Math.log2(x) | 0;\n const coeff = x / 2 ** exponent;\n return `${numberToStringFixed(coeff, 1)}p${exponent}`;\n }\n return Math.round(x) + \"\";\n}\n\nexport interface RenderScaleWidgetOptions {\n histogram: RenderScaleHistogram;\n target: TrackableValueInterface;\n}\n\nexport class RenderScaleWidget extends RefCounted {\n label = document.createElement(\"div\");\n element = document.createElement(\"div\");\n canvas = document.createElement(\"canvas\");\n legend = document.createElement(\"div\");\n legendRenderScale = document.createElement(\"div\");\n legendSpatialScale = document.createElement(\"div\");\n legendChunks = document.createElement(\"div\");\n protected logScaleOrigin = renderScaleHistogramOrigin;\n protected unitOfTarget = \"px\";\n private ctx = this.canvas.getContext(\"2d\")!;\n hoverTarget = new WatchableValue<[number, number] | undefined>(undefined);\n private throttledUpdateView = this.registerCancellable(\n throttle(() => this.debouncedUpdateView(), updateInterval, {\n leading: true,\n trailing: true,\n }),\n );\n private debouncedUpdateView = this.registerCancellable(\n debounce(() => this.updateView(), 0),\n );\n\n adjustViaWheel(event: WheelEvent) {\n const deltaY = this.getWheelMoveValue(event);\n if (deltaY === 0) {\n return;\n }\n this.hoverTarget.value = undefined;\n const logScaleMax = Math.round(\n this.logScaleOrigin +\n numRenderScaleHistogramBins * renderScaleHistogramBinSize,\n );\n const targetValue = clampToInterval(\n [2 ** this.logScaleOrigin, 2 ** (logScaleMax - 1)],\n this.target.value * 2 ** Math.sign(deltaY),\n ) as number;\n this.target.value = targetValue;\n event.preventDefault();\n }\n\n constructor(\n public histogram: RenderScaleHistogram,\n public target: TrackableValueInterface,\n ) {\n super();\n const {\n canvas,\n label,\n element,\n legend,\n legendRenderScale,\n legendSpatialScale,\n legendChunks,\n } = this;\n label.className = \"neuroglancer-render-scale-widget-prompt\";\n element.className = \"neuroglancer-render-scale-widget\";\n element.title = inputEventMap.describe();\n legend.className = \"neuroglancer-render-scale-widget-legend\";\n element.appendChild(label);\n element.appendChild(canvas);\n element.appendChild(legend);\n legendRenderScale.title = \"Target resolution of data in screen pixels\";\n legendChunks.title = \"Number of chunks rendered\";\n legend.appendChild(legendRenderScale);\n legend.appendChild(legendChunks);\n legend.appendChild(legendSpatialScale);\n this.registerDisposer(histogram.changed.add(this.throttledUpdateView));\n this.registerDisposer(\n histogram.visibility.changed.add(this.debouncedUpdateView),\n );\n this.registerDisposer(target.changed.add(this.debouncedUpdateView));\n this.registerDisposer(new MouseEventBinder(canvas, inputEventMap));\n this.registerDisposer(target.changed.add(this.debouncedUpdateView));\n this.registerDisposer(\n this.hoverTarget.changed.add(this.debouncedUpdateView),\n );\n\n const getTargetValue = (event: MouseEvent) => {\n const position =\n (event.offsetX / canvas.width) * numRenderScaleHistogramBins;\n return getRenderScaleFromHistogramOffset(position, this.logScaleOrigin);\n };\n this.registerEventListener(canvas, \"pointermove\", (event: MouseEvent) => {\n this.hoverTarget.value = [getTargetValue(event), event.offsetY];\n });\n\n this.registerEventListener(canvas, \"pointerleave\", () => {\n this.hoverTarget.value = undefined;\n });\n\n this.registerDisposer(\n registerActionListener(canvas, \"set\", (actionEvent) => {\n this.target.value = getTargetValue(actionEvent.detail);\n }),\n );\n\n this.registerDisposer(\n registerActionListener(\n canvas,\n \"adjust-via-wheel\",\n (actionEvent) => {\n this.adjustViaWheel(actionEvent.detail);\n },\n ),\n );\n\n this.registerDisposer(\n registerActionListener(canvas, \"reset\", (event) => {\n this.reset();\n event.preventDefault();\n }),\n );\n const resizeObserver = new ResizeObserver(() => this.debouncedUpdateView());\n resizeObserver.observe(canvas);\n this.registerDisposer(() => resizeObserver.disconnect());\n this.updateView();\n }\n\n getWheelMoveValue(event: WheelEvent) {\n return event.deltaY;\n }\n\n reset() {\n this.hoverTarget.value = undefined;\n this.target.reset();\n }\n\n updateView() {\n const { ctx } = this;\n const { canvas } = this;\n const width = (canvas.width = canvas.offsetWidth);\n const height = (canvas.height = canvas.offsetHeight);\n const targetValue = this.target.value;\n const hoverValue = this.hoverTarget.value;\n\n {\n const { legendRenderScale } = this;\n const value = hoverValue === undefined ? targetValue : hoverValue[0];\n const valueString = formatPixelNumber(value);\n legendRenderScale.textContent = valueString + \" \" + this.unitOfTarget;\n }\n\n function binToCanvasX(bin: number) {\n return (bin * width) / numRenderScaleHistogramBins;\n }\n\n ctx.clearRect(0, 0, width, height);\n\n const { histogram } = this;\n // histogram.begin(this.frameNumberCounter.frameNumber);\n const { value: histogramData, spatialScales } = histogram;\n\n if (!histogram.visibility.visible) {\n histogramData.fill(0);\n }\n\n const sortedSpatialScales = Array.from(spatialScales.keys());\n sortedSpatialScales.sort();\n\n const tempColor = vec3.create();\n\n let maxCount = 1;\n const numRows = spatialScales.size;\n let totalPresent = 0;\n let totalNotPresent = 0;\n for (let bin = 0; bin < numRenderScaleHistogramBins; ++bin) {\n let count = 0;\n for (let row = 0; row < numRows; ++row) {\n const index = row * numRenderScaleHistogramBins * 2 + bin;\n const presentCount = histogramData[index];\n const notPresentCount =\n histogramData[index + numRenderScaleHistogramBins];\n totalPresent += presentCount;\n totalNotPresent += notPresentCount;\n count += presentCount + notPresentCount;\n }\n maxCount = Math.max(count, maxCount);\n }\n totalNotPresent -= histogram.fakeChunkCount;\n\n const maxBarHeight = height;\n\n const yScale = maxBarHeight / Math.log(1 + maxCount);\n\n function countToCanvasY(count: number) {\n return height - Math.log(1 + count) * yScale;\n }\n\n let hoverSpatialScale: number | undefined = undefined;\n if (hoverValue !== undefined) {\n const i = Math.floor(\n getRenderScaleHistogramOffset(hoverValue[0], this.logScaleOrigin),\n );\n if (i >= 0 && i < numRenderScaleHistogramBins) {\n let sum = 0;\n const hoverY = hoverValue[1];\n for (\n let spatialScaleIndex = numRows - 1;\n spatialScaleIndex >= 0;\n --spatialScaleIndex\n ) {\n const spatialScale = sortedSpatialScales[spatialScaleIndex];\n const row = spatialScales.get(spatialScale)!;\n const index = 2 * row * numRenderScaleHistogramBins + i;\n const count =\n histogramData[index] +\n histogramData[index + numRenderScaleHistogramBins];\n if (count === 0) continue;\n const yStart = Math.round(countToCanvasY(sum));\n sum += count;\n const yEnd = Math.round(countToCanvasY(sum));\n if (yEnd <= hoverY && hoverY <= yStart) {\n hoverSpatialScale = spatialScale;\n break;\n }\n }\n }\n }\n if (hoverSpatialScale !== undefined) {\n totalPresent = 0;\n totalNotPresent = 0;\n const row = spatialScales.get(hoverSpatialScale)!;\n const baseIndex = 2 * row * numRenderScaleHistogramBins;\n for (let bin = 0; bin < numRenderScaleHistogramBins; ++bin) {\n const index = baseIndex + bin;\n totalPresent += histogramData[index];\n totalNotPresent += histogramData[index + numRenderScaleHistogramBins];\n }\n if (Number.isFinite(hoverSpatialScale)) {\n this.legendSpatialScale.textContent = formatScaleWithUnitAsString(\n hoverSpatialScale,\n \"m\",\n { precision: 2, elide1: false },\n );\n } else {\n this.legendSpatialScale.textContent = \"unknown\";\n }\n } else {\n this.legendSpatialScale.textContent = \"\";\n }\n\n this.legendChunks.textContent = `${totalPresent}/${\n totalPresent + totalNotPresent\n }`;\n\n const spatialScaleColors = sortedSpatialScales.map((spatialScale) => {\n const saturation = spatialScale === hoverSpatialScale ? 0.5 : 1;\n let hue;\n if (Number.isFinite(spatialScale)) {\n hue = (((Math.log2(spatialScale) * 0.1) % 1) + 1) % 1;\n } else {\n hue = 0;\n }\n hsvToRgb(tempColor, hue, saturation, 1);\n const presentColor = serializeColor(tempColor);\n hsvToRgb(tempColor, hue, saturation, 0.5);\n const notPresentColor = serializeColor(tempColor);\n return [presentColor, notPresentColor];\n });\n\n for (let i = 0; i < numRenderScaleHistogramBins; ++i) {\n let sum = 0;\n for (\n let spatialScaleIndex = numRows - 1;\n spatialScaleIndex >= 0;\n --spatialScaleIndex\n ) {\n const spatialScale = sortedSpatialScales[spatialScaleIndex];\n const row = spatialScales.get(spatialScale)!;\n const index = row * numRenderScaleHistogramBins * 2 + i;\n const presentCount = histogramData[index];\n const notPresentCount =\n histogramData[index + numRenderScaleHistogramBins];\n const count = presentCount + notPresentCount;\n if (count === 0) continue;\n const xStart = Math.round(binToCanvasX(i));\n const xEnd = Math.round(binToCanvasX(i + 1));\n const yStart = Math.round(countToCanvasY(sum));\n sum += count;\n const yEnd = Math.round(countToCanvasY(sum));\n const ySplit = (presentCount * yEnd + notPresentCount * yStart) / count;\n ctx.fillStyle = spatialScaleColors[spatialScaleIndex][1];\n ctx.fillRect(xStart, yEnd, xEnd - xStart, ySplit - yEnd);\n ctx.fillStyle = spatialScaleColors[spatialScaleIndex][0];\n ctx.fillRect(xStart, ySplit, xEnd - xStart, yStart - ySplit);\n }\n }\n\n {\n const value = targetValue;\n ctx.fillStyle = \"#fff\";\n const startOffset = binToCanvasX(\n getRenderScaleHistogramOffset(value, this.logScaleOrigin),\n );\n const lineWidth = 1;\n ctx.fillRect(Math.floor(startOffset), 0, lineWidth, height);\n }\n\n if (hoverValue !== undefined) {\n const value = hoverValue[0];\n ctx.fillStyle = \"#888\";\n const startOffset = binToCanvasX(\n getRenderScaleHistogramOffset(value, this.logScaleOrigin),\n );\n const lineWidth = 1;\n ctx.fillRect(Math.floor(startOffset), 0, lineWidth, height);\n }\n }\n}\n\nexport class VolumeRenderingRenderScaleWidget extends RenderScaleWidget {\n protected unitOfTarget = \"samples\";\n protected logScaleOrigin = 1;\n\n getWheelMoveValue(event: WheelEvent) {\n return -event.deltaY;\n }\n}\n\nconst TOOL_INPUT_EVENT_MAP = EventActionMap.fromObject({\n \"at:shift+wheel\": { action: \"adjust-via-wheel\" },\n \"at:shift+dblclick0\": { action: \"reset\" },\n});\n\nexport function renderScaleLayerControl<\n LayerType extends UserLayer,\n WidgetType extends RenderScaleWidget,\n>(\n getter: (layer: LayerType) => RenderScaleWidgetOptions,\n widgetClass: new (\n histogram: RenderScaleHistogram,\n target: TrackableValueInterface,\n ) => WidgetType = RenderScaleWidget as new (\n histogram: RenderScaleHistogram,\n target: TrackableValueInterface,\n ) => WidgetType,\n): LayerControlFactory {\n return {\n makeControl: (layer, context) => {\n const { histogram, target } = getter(layer);\n const control = context.registerDisposer(\n new widgetClass(histogram, target),\n );\n return { control, controlElement: control.element };\n },\n activateTool: (activation, control) => {\n activation.bindInputEventMap(TOOL_INPUT_EVENT_MAP);\n activation.bindAction(\n \"adjust-via-wheel\",\n (event: ActionEvent) => {\n event.stopPropagation();\n event.preventDefault();\n control.adjustViaWheel(event.detail);\n },\n );\n activation.bindAction(\"reset\", (event: ActionEvent) => {\n event.stopPropagation();\n event.preventDefault();\n control.reset();\n });\n },\n };\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { UserLayer } from \"#src/layer/index.js\";\nimport type { WatchableValueInterface } from \"#src/trackable_value.js\";\nimport type { ActionEvent } from \"#src/util/event_action_map.js\";\nimport { EventActionMap } from \"#src/util/event_action_map.js\";\nimport type { vec3 } from \"#src/util/geom.js\";\nimport { ColorWidget } from \"#src/widget/color.js\";\nimport type { LayerControlFactory } from \"#src/widget/layer_control.js\";\n\nconst TOOL_INPUT_EVENT_MAP = EventActionMap.fromObject({\n \"at:shift+wheel\": { action: \"adjust-hue-via-wheel\" },\n});\n\nexport function colorLayerControl<\n LayerType extends UserLayer,\n Color extends vec3 | undefined,\n>(\n getter: (layer: LayerType) => WatchableValueInterface,\n): LayerControlFactory> {\n return {\n makeControl: (layer, context) => {\n const value = getter(layer);\n const control = context.registerDisposer(new ColorWidget(value));\n return { control, controlElement: control.element };\n },\n activateTool: (activation, control) => {\n activation.bindInputEventMap(TOOL_INPUT_EVENT_MAP);\n activation.bindAction(\n \"adjust-via-wheel\",\n (event: ActionEvent) => {\n event.stopPropagation();\n event.preventDefault();\n control.adjustHueViaWheel(event.detail);\n },\n );\n },\n };\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { TrackableValueInterface } from \"#src/trackable_value.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { removeFromParent } from \"#src/util/dom.js\";\n\nexport class TextInputWidget extends RefCounted {\n element = document.createElement(\"input\");\n constructor(public model: TrackableValueInterface) {\n super();\n this.registerDisposer(model.changed.add(() => this.updateView()));\n const { element } = this;\n element.type = \"text\";\n this.registerEventListener(element, \"change\", () => this.updateModel());\n this.updateView();\n }\n\n disposed() {\n removeFromParent(this.element);\n }\n\n private updateView() {\n this.element.value = (this.model.value ?? \"\") + \"\";\n }\n\n private updateModel() {\n try {\n this.model.restoreState(this.element.value);\n } catch {\n // Ignore invalid input.\n }\n this.updateView();\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/segmentation_color_mode.css\";\n\nimport svg_rotate from \"ikonate/icons/rotate.svg?raw\";\nimport type { SegmentationUserLayer } from \"#src/layer/segmentation/index.js\";\nimport { observeWatchable } from \"#src/trackable_value.js\";\nimport { vec3 } from \"#src/util/geom.js\";\nimport type { ColorWidget } from \"#src/widget/color.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\nimport type { LayerControlFactory } from \"#src/widget/layer_control.js\";\nimport { colorLayerControl } from \"#src/widget/layer_control_color.js\";\nimport { TextInputWidget } from \"#src/widget/text_input.js\";\n\nfunction chooseColorMode(layer: SegmentationUserLayer, useFixedColor: boolean) {\n if (!useFixedColor) {\n layer.displayState.segmentDefaultColor.value = undefined;\n } else {\n layer.displayState.segmentDefaultColor.value = vec3.fromValues(1, 0, 0);\n }\n}\n\nexport function colorSeedLayerControl(): LayerControlFactory {\n const randomize = (layer: SegmentationUserLayer) => {\n layer.displayState.segmentationColorGroupState.value.segmentColorHash.randomize();\n };\n return {\n makeControl: (layer, context, { labelTextContainer }) => {\n const checkbox = document.createElement(\"input\");\n checkbox.type = \"radio\";\n checkbox.addEventListener(\"change\", () => {\n chooseColorMode(layer, !checkbox.checked);\n });\n labelTextContainer.prepend(checkbox);\n const controlElement = document.createElement(\"div\");\n controlElement.classList.add(\n \"neuroglancer-segmentation-color-seed-control\",\n );\n const widget = context.registerDisposer(\n new TextInputWidget(layer.displayState.segmentColorHash),\n );\n controlElement.appendChild(widget.element);\n const randomizeButton = makeIcon({\n svg: svg_rotate,\n title: \"Randomize\",\n onClick: () => randomize(layer),\n });\n controlElement.appendChild(randomizeButton);\n context.registerDisposer(\n observeWatchable((value) => {\n const isVisible = value === undefined;\n controlElement.style.visibility = isVisible ? \"\" : \"hidden\";\n checkbox.checked = isVisible;\n }, layer.displayState.segmentDefaultColor),\n );\n return { controlElement, control: widget };\n },\n activateTool: (activation) => {\n const { layer } = activation.tool;\n chooseColorMode(layer, false);\n randomize(layer);\n },\n };\n}\n\nexport function fixedColorLayerControl(): LayerControlFactory<\n SegmentationUserLayer,\n ColorWidget\n> {\n const options = colorLayerControl(\n (layer: SegmentationUserLayer) => layer.displayState.segmentDefaultColor,\n );\n return {\n ...options,\n makeControl: (layer, context, labelElements) => {\n const result = options.makeControl(layer, context, labelElements);\n const { controlElement } = result;\n const checkbox = document.createElement(\"input\");\n checkbox.type = \"radio\";\n checkbox.addEventListener(\"change\", () => {\n chooseColorMode(layer, checkbox.checked);\n if (checkbox.checked) {\n controlElement.click();\n }\n });\n labelElements.labelTextContainer.prepend(checkbox);\n context.registerDisposer(\n observeWatchable((value) => {\n const isVisible = value !== undefined;\n controlElement.style.visibility = isVisible ? \"\" : \"hidden\";\n checkbox.checked = isVisible;\n }, layer.displayState.segmentDefaultColor),\n );\n return result;\n },\n activateTool: (activation, control) => {\n chooseColorMode(activation.tool.layer, true);\n options.activateTool(activation, control);\n },\n };\n}\n","import type { SegmentationUserLayer } from \"#src/layer/segmentation/index.js\";\nimport * as json_keys from \"#src/layer/segmentation/json_keys.js\";\nimport type { LayerControlDefinition } from \"#src/widget/layer_control.js\";\nimport { registerLayerControl } from \"#src/widget/layer_control.js\";\nimport { checkboxLayerControl } from \"#src/widget/layer_control_checkbox.js\";\nimport { enumLayerControl } from \"#src/widget/layer_control_enum.js\";\nimport { rangeLayerControl } from \"#src/widget/layer_control_range.js\";\nimport { renderScaleLayerControl } from \"#src/widget/render_scale_widget.js\";\nimport {\n colorSeedLayerControl,\n fixedColorLayerControl,\n} from \"#src/widget/segmentation_color_mode.js\";\n\nexport const LAYER_CONTROLS: LayerControlDefinition[] = [\n {\n label: \"Color seed\",\n title: \"Color segments based on a hash of their id\",\n toolJson: json_keys.COLOR_SEED_JSON_KEY,\n ...colorSeedLayerControl(),\n },\n {\n label: \"Fixed color\",\n title:\n \"Use a fixed color for all segments without an explicitly-specified color\",\n toolJson: json_keys.SEGMENT_DEFAULT_COLOR_JSON_KEY,\n ...fixedColorLayerControl(),\n },\n {\n label: \"Saturation\",\n toolJson: json_keys.SATURATION_JSON_KEY,\n title: \"Saturation of segment colors\",\n ...rangeLayerControl((layer) => ({ value: layer.displayState.saturation })),\n },\n {\n label: \"Opacity (on)\",\n toolJson: json_keys.SELECTED_ALPHA_JSON_KEY,\n isValid: (layer) => layer.has2dLayer,\n title: \"Opacity in cross-section views of segments that are selected\",\n ...rangeLayerControl((layer) => ({\n value: layer.displayState.selectedAlpha,\n })),\n },\n {\n label: \"Opacity (off)\",\n toolJson: json_keys.NOT_SELECTED_ALPHA_JSON_KEY,\n isValid: (layer) => layer.has2dLayer,\n title: \"Opacity in cross-section views of segments that are not selected\",\n ...rangeLayerControl((layer) => ({\n value: layer.displayState.notSelectedAlpha,\n })),\n },\n {\n label: \"Resolution (slice)\",\n toolJson: json_keys.CROSS_SECTION_RENDER_SCALE_JSON_KEY,\n isValid: (layer) => layer.has2dLayer,\n ...renderScaleLayerControl((layer) => ({\n histogram: layer.sliceViewRenderScaleHistogram,\n target: layer.sliceViewRenderScaleTarget,\n })),\n },\n {\n label: \"Resolution (mesh)\",\n toolJson: json_keys.MESH_RENDER_SCALE_JSON_KEY,\n isValid: (layer) => layer.has3dLayer,\n ...renderScaleLayerControl((layer) => ({\n histogram: layer.displayState.renderScaleHistogram,\n target: layer.displayState.renderScaleTarget,\n })),\n },\n {\n label: \"Opacity (3d)\",\n toolJson: json_keys.OBJECT_ALPHA_JSON_KEY,\n isValid: (layer) => layer.has3dLayer,\n title: \"Opacity of meshes and skeletons\",\n ...rangeLayerControl((layer) => ({\n value: layer.displayState.objectAlpha,\n })),\n },\n {\n label: \"Silhouette (3d)\",\n toolJson: json_keys.MESH_SILHOUETTE_RENDERING_JSON_KEY,\n isValid: (layer) => layer.has3dLayer,\n title:\n \"Set to a non-zero value to increase transparency of object faces perpendicular to view direction\",\n ...rangeLayerControl((layer) => ({\n value: layer.displayState.silhouetteRendering,\n options: { min: 0, max: maxSilhouettePower, step: 0.1 },\n })),\n },\n {\n label: \"Hide segment ID 0\",\n toolJson: json_keys.HIDE_SEGMENT_ZERO_JSON_KEY,\n title: \"Disallow selection and display of segment id 0\",\n ...checkboxLayerControl((layer) => layer.displayState.hideSegmentZero),\n },\n {\n label: \"Base segment coloring\",\n toolJson: json_keys.BASE_SEGMENT_COLORING_JSON_KEY,\n title: \"Color base segments individually\",\n ...checkboxLayerControl((layer) => layer.displayState.baseSegmentColoring),\n },\n {\n label: \"Show all by default\",\n title: \"Show all segments if none are selected\",\n toolJson: json_keys.IGNORE_NULL_VISIBLE_SET_JSON_KEY,\n ...checkboxLayerControl((layer) => layer.displayState.ignoreNullVisibleSet),\n },\n {\n label: \"Highlight on hover\",\n toolJson: json_keys.HOVER_HIGHLIGHT_JSON_KEY,\n title: \"Highlight the segment under the mouse pointer\",\n ...checkboxLayerControl((layer) => layer.displayState.hoverHighlight),\n },\n ...getViewSpecificSkeletonRenderingControl(\"2d\"),\n ...getViewSpecificSkeletonRenderingControl(\"3d\"),\n];\n\nconst maxSilhouettePower = 10;\n\nfunction getViewSpecificSkeletonRenderingControl(\n viewName: \"2d\" | \"3d\",\n): LayerControlDefinition[] {\n return [\n {\n label: `Skeleton mode (${viewName})`,\n toolJson: `${json_keys.SKELETON_RENDERING_JSON_KEY}.mode${viewName}`,\n isValid: (layer) => layer.hasSkeletonsLayer,\n ...enumLayerControl(\n (layer) =>\n layer.displayState.skeletonRenderingOptions[\n `params${viewName}` as const\n ].mode,\n ),\n },\n {\n label: `Line width (${viewName})`,\n toolJson: `${json_keys.SKELETON_RENDERING_JSON_KEY}.lineWidth${viewName}`,\n isValid: (layer) => layer.hasSkeletonsLayer,\n toolDescription: `Skeleton line width (${viewName})`,\n title: `Skeleton line width (${viewName})`,\n ...rangeLayerControl((layer) => ({\n value:\n layer.displayState.skeletonRenderingOptions[\n `params${viewName}` as const\n ].lineWidth,\n options: { min: 1, max: 40, step: 1 },\n })),\n },\n ];\n}\n\nexport function registerLayerControls(layerType: typeof SegmentationUserLayer) {\n for (const control of LAYER_CONTROLS) {\n registerLayerControl(layerType, control);\n }\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { TypedArray } from \"#src/util/array.js\";\nimport type { Uint64 } from \"#src/util/uint64.js\";\n\nexport function getOctreeChildIndex(x: number, y: number, z: number) {\n return (x & 1) | ((y << 1) & 2) | ((z << 2) & 4);\n}\n\n/**\n * Decodes a \"compressed\" 3-d morton index.\n *\n * Decoded bit `i` of `x`, `y`, and `z` is at bit `i + min(i, yBits) + min(i, zBits)`, `i + min(i +\n * 1, xBits) + min(i, zBits)`, and `i + min(i + 1, xBits) + min(i + 1, zBits)` of `zindex`,\n * respectively, for `i` in `[0, xBits)`, `[0, yBits)`, `[0, zBits)`, respectively.\n */\nexport function decodeZIndexCompressed(\n zindex: Uint64,\n xBits: number,\n yBits: number,\n zBits: number,\n): Uint32Array {\n const maxCoordBits = Math.max(xBits, yBits, zBits);\n let inputBit = 0;\n let inputValue = zindex.low;\n let x = 0;\n let y = 0;\n let z = 0;\n for (let coordBit = 0; coordBit < maxCoordBits; ++coordBit) {\n if (coordBit < xBits) {\n const bit = (inputValue >>> inputBit) & 1;\n x |= bit << coordBit;\n if (inputBit === 31) {\n inputBit = 0;\n inputValue = zindex.high;\n } else {\n ++inputBit;\n }\n }\n if (coordBit < yBits) {\n const bit = (inputValue >>> inputBit) & 1;\n y |= bit << coordBit;\n if (inputBit === 31) {\n inputBit = 0;\n inputValue = zindex.high;\n } else {\n ++inputBit;\n }\n }\n if (coordBit < zBits) {\n const bit = (inputValue >>> inputBit) & 1;\n z |= bit << coordBit;\n if (inputBit === 31) {\n inputBit = 0;\n inputValue = zindex.high;\n } else {\n ++inputBit;\n }\n }\n }\n return Uint32Array.of(x, y, z);\n}\n\nexport function encodeZIndexCompressed3d(\n zindex: Uint64,\n xBits: number,\n yBits: number,\n zBits: number,\n x: number,\n y: number,\n z: number,\n): Uint64 {\n const maxBits = Math.max(xBits, yBits, zBits);\n let outputBit = 0;\n let outputNum = 0;\n let isHigh = false;\n function writeBit(b: number): void {\n outputNum |= (b & 1) << outputBit;\n if (++outputBit === 32) {\n zindex.low = outputNum >>> 0;\n outputNum = 0;\n outputBit = 0;\n isHigh = true;\n }\n }\n for (let bit = 0; bit < maxBits; ++bit) {\n if (bit < xBits) {\n writeBit((x >> bit) & 1);\n }\n if (bit < yBits) {\n writeBit((y >> bit) & 1);\n }\n if (bit < zBits) {\n writeBit((z >> bit) & 1);\n }\n }\n if (isHigh) {\n zindex.high = outputNum >>> 0;\n } else {\n zindex.high = 0;\n zindex.low = outputNum >>> 0;\n }\n return zindex;\n}\n\nexport function encodeZIndexCompressed(\n zindex: Uint64,\n position: TypedArray,\n shape: TypedArray,\n): Uint64 {\n let outputBit = 0;\n const rank = position.length;\n let outputNum = 0;\n let isHigh = false;\n function writeBit(b: number): void {\n outputNum |= (b & 1) << outputBit;\n if (++outputBit === 32) {\n zindex.low = outputNum >>> 0;\n outputNum = 0;\n outputBit = 0;\n isHigh = true;\n }\n }\n\n for (let bit = 0; bit < 32; ++bit) {\n for (let dim = 0; dim < rank; ++dim) {\n if ((shape[dim] - 1) >>> bit) {\n writeBit(position[dim] >>> bit);\n }\n }\n }\n if (isHigh) {\n zindex.high = outputNum >>> 0;\n } else {\n zindex.high = 0;\n zindex.low = outputNum >>> 0;\n }\n return zindex;\n}\n\nfunction lessMsb(a: number, b: number) {\n return a < b && a < (a ^ b);\n}\n\n/**\n * Returns `true` if `(x0, y0, z0)` occurs before `(x1, y1, z1)` in Z-curve order.\n */\nexport function zorder3LessThan(\n x0: number,\n y0: number,\n z0: number,\n x1: number,\n y1: number,\n z1: number,\n): boolean {\n let mostSignificant0 = z0;\n let mostSignificant1 = z1;\n\n if (lessMsb(mostSignificant0 ^ mostSignificant1, y0 ^ y1)) {\n mostSignificant0 = y0;\n mostSignificant1 = y1;\n }\n\n if (lessMsb(mostSignificant0 ^ mostSignificant1, x0 ^ x1)) {\n mostSignificant0 = x0;\n mostSignificant1 = x1;\n }\n\n return mostSignificant0 < mostSignificant1;\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { mat4, vec3 } from \"#src/util/geom.js\";\nimport { isAABBVisible } from \"#src/util/geom.js\";\nimport { getOctreeChildIndex } from \"#src/util/zorder.js\";\n\nconst DEBUG_CHUNKS_TO_DRAW = false;\n\nexport interface MultiscaleMeshManifest {\n /**\n * Size of finest-resolution (base) chunk in object coordinates.\n */\n chunkShape: vec3;\n\n /**\n * Starting corner position of (0, 0, 0) chunk in object coordinates.\n */\n chunkGridSpatialOrigin: vec3;\n\n /**\n * Axis-aligned bounding box lower bound of object in object coordinates to use for clipping and\n * level-of-detail calculations.\n */\n clipLowerBound: vec3;\n\n /**\n * Axis-aligned bounding box upper bound of object in object coordinates to use for clipping and\n * level-of-detail calculations.\n */\n clipUpperBound: vec3;\n\n /**\n * Specifies the number of levels of detail (as `lodScales.length`), and the resolution in object\n * coordinates for each level of detail. If `lodScales[lod] === 0`, then level-of-detail `lod`\n * does not exist.\n *\n * Level of detail `0` is the finest resolution.\n *\n * The non-zero values must be non-decreasing.\n *\n * For each chunk, the chosen `lod` is the largest value such that\n * `lodScales[lod] <= detailCutoff * pixelSize`, where `pixelSize` is the maximum spatial distance\n * spanned by a single viewport pixel within the projected image of the chunk.\n */\n lodScales: Float32Array;\n\n /**\n * C order `[numLods, 3]` array specifying the xyz vertex position offset in object coordinates\n * for each level of detail.\n */\n vertexOffsets: Float32Array;\n\n /**\n * Row-major `[n, 5]` array where each row is of the form `[x, y, z, start, end_and_empty]`, where\n * `x`, `y`, and `z` are the chunk grid coordinates of the entry at a particular level of detail.\n * Row `n-1` corresponds to level of detail `lodScales.length - 1`, the root of the octree. Given\n * a row corresponding to an octree node at level of detail `lod`, bits `start` specifies the row\n * number of the first child octree node at level of detail `lod-1`, and bits `[0,30]` of\n * `end_and_empty` specify one past the row number of the last child octree node. Bit `31` of\n * `end_and_empty` is set to `1` if the mesh for the octree node is empty and should not be\n * requested/rendered.\n */\n octree: Uint32Array;\n}\n\n/**\n * @param detailCutoff Factor by which the spatial resolution of the mesh may be worse than the\n * spatial resolution of a single viewport pixel. For example, a value of 10 means that if a\n * given portion of the object will be rendered such that a pixel corresponds to 50 nm, then a\n * mesh level of detail down to 500 nm will be requested for that portion of the object.\n */\nexport function getDesiredMultiscaleMeshChunks(\n manifest: MultiscaleMeshManifest,\n modelViewProjection: mat4,\n clippingPlanes: Float32Array,\n detailCutoff: number,\n viewportWidth: number,\n viewportHeight: number,\n callback: (\n lod: number,\n row: number,\n renderScale: number,\n empty: number,\n ) => void,\n) {\n const { octree, lodScales, chunkGridSpatialOrigin, chunkShape } = manifest;\n const maxLod = lodScales.length - 1;\n const m00 = modelViewProjection[0];\n const m01 = modelViewProjection[4];\n const m02 = modelViewProjection[8];\n const m10 = modelViewProjection[1];\n const m11 = modelViewProjection[5];\n const m12 = modelViewProjection[9];\n const m30 = modelViewProjection[3];\n const m31 = modelViewProjection[7];\n const m32 = modelViewProjection[11];\n const m33 = modelViewProjection[15];\n\n const minWXcoeff = m30 > 0 ? 0 : 1;\n const minWYcoeff = m31 > 0 ? 0 : 1;\n const minWZcoeff = m32 > 0 ? 0 : 1;\n\n const nearA = clippingPlanes[4 * 4];\n const nearB = clippingPlanes[4 * 4 + 1];\n const nearC = clippingPlanes[4 * 4 + 2];\n const nearD = clippingPlanes[4 * 4 + 3];\n\n function getPointW(x: number, y: number, z: number) {\n return m30 * x + m31 * y + m32 * z + m33;\n }\n\n function getBoxW(\n xLower: number,\n yLower: number,\n zLower: number,\n xUpper: number,\n yUpper: number,\n zUpper: number,\n ) {\n return getPointW(\n xLower + minWXcoeff * (xUpper - xLower),\n yLower + minWYcoeff * (yUpper - yLower),\n zLower + minWZcoeff * (zUpper - zLower),\n );\n }\n\n /**\n * Minimum value of w within clipping frustrum (under the assumption that the minimum value occurs\n * on the near clipping plane).\n */\n const minWClip = getPointW(-nearD * nearA, -nearD * nearB, -nearD * nearC);\n\n const objectXLower = manifest.clipLowerBound[0];\n const objectYLower = manifest.clipLowerBound[1];\n const objectZLower = manifest.clipLowerBound[2];\n const objectXUpper = manifest.clipUpperBound[0];\n const objectYUpper = manifest.clipUpperBound[1];\n const objectZUpper = manifest.clipUpperBound[2];\n\n const xScale = Math.sqrt(\n (m00 * viewportWidth) ** 2 + (m10 * viewportHeight) ** 2,\n );\n const yScale = Math.sqrt(\n (m01 * viewportWidth) ** 2 + (m11 * viewportHeight) ** 2,\n );\n const zScale = Math.sqrt(\n (m02 * viewportWidth) ** 2 + (m12 * viewportHeight) ** 2,\n );\n\n const scaleFactor = Math.max(xScale, yScale, zScale);\n\n function handleChunk(lod: number, row: number, priorLodScale: number) {\n const size = 1 << lod;\n const rowOffset = row * 5;\n const gridX = octree[rowOffset];\n const gridY = octree[rowOffset + 1];\n const gridZ = octree[rowOffset + 2];\n const childBegin = octree[rowOffset + 3];\n const childEndAndEmpty = octree[rowOffset + 4];\n let xLower = gridX * size * chunkShape[0] + chunkGridSpatialOrigin[0];\n let yLower = gridY * size * chunkShape[1] + chunkGridSpatialOrigin[1];\n let zLower = gridZ * size * chunkShape[2] + chunkGridSpatialOrigin[2];\n let xUpper = xLower + size * chunkShape[0];\n let yUpper = yLower + size * chunkShape[1];\n let zUpper = zLower + size * chunkShape[2];\n xLower = Math.max(xLower, objectXLower);\n yLower = Math.max(yLower, objectYLower);\n zLower = Math.max(zLower, objectZLower);\n xUpper = Math.min(xUpper, objectXUpper);\n yUpper = Math.min(yUpper, objectYUpper);\n zUpper = Math.min(zUpper, objectZUpper);\n\n if (\n isAABBVisible(\n xLower,\n yLower,\n zLower,\n xUpper,\n yUpper,\n zUpper,\n clippingPlanes,\n )\n ) {\n const minW = Math.max(\n minWClip,\n getBoxW(xLower, yLower, zLower, xUpper, yUpper, zUpper),\n );\n const pixelSize = minW / scaleFactor;\n\n if (priorLodScale === 0 || pixelSize * detailCutoff < priorLodScale) {\n const lodScale = lodScales[lod];\n if (lodScale !== 0) {\n callback(lod, row, lodScale / pixelSize, childEndAndEmpty >>> 31);\n }\n\n if (\n lod > 0 &&\n (lodScale === 0 || pixelSize * detailCutoff < lodScale)\n ) {\n const nextPriorLodScale = lodScale === 0 ? priorLodScale : lodScale;\n const childEnd = (childEndAndEmpty & 0x7fffffff) >>> 0;\n for (let childRow = childBegin; childRow < childEnd; ++childRow) {\n handleChunk(lod - 1, childRow, nextPriorLodScale);\n }\n }\n }\n }\n }\n handleChunk(maxLod, octree.length / 5 - 1, 0);\n}\n\nexport function getMultiscaleChunksToDraw(\n manifest: MultiscaleMeshManifest,\n modelViewProjection: mat4,\n clippingPlanes: Float32Array,\n detailCutoff: number,\n viewportWidth: number,\n viewportHeight: number,\n hasChunk: (lod: number, row: number, renderScale: number) => boolean,\n callback: (\n lod: number,\n row: number,\n subChunkBegin: number,\n subChunkEnd: number,\n renderScale: number,\n ) => void,\n) {\n const { lodScales } = manifest;\n let maxLod = 0;\n while (maxLod + 1 < lodScales.length && lodScales[maxLod + 1] !== 0) {\n ++maxLod;\n }\n\n const stackEntryStride = 3;\n\n // [row, parentSubChunkIndex, renderScale]\n const stack: number[] = [];\n let stackDepth = 0;\n let priorSubChunkIndex = 0;\n function emitChunksUpTo(targetStackIndex: number, subChunkIndex: number) {\n if (DEBUG_CHUNKS_TO_DRAW) {\n console.log(\n `emitChunksUpTo: stackDepth=${stackDepth}, targetStackIndex=${targetStackIndex}, subChunkIndex=${subChunkIndex}, priorSubChunkIndex=${priorSubChunkIndex}`,\n );\n }\n while (true) {\n if (stackDepth === 0) return;\n\n // Finish last chunk of last (finest) lod.\n const stackIndex = stackDepth - 1;\n const entryLod = maxLod - stackIndex;\n const entryRow = stack[stackIndex * stackEntryStride];\n const numSubChunks = entryLod === 0 ? 1 : 8;\n const entrySubChunkIndex = stack[stackIndex * stackEntryStride + 1];\n const entryRenderScale = stack[stackIndex * stackEntryStride + 2];\n if (targetStackIndex === stackDepth) {\n const endSubChunk = subChunkIndex & (numSubChunks - 1);\n\n if (priorSubChunkIndex !== endSubChunk && entryRow !== -1) {\n if (DEBUG_CHUNKS_TO_DRAW) {\n console.log(\n ` drawing chunk because priorSubChunkIndex (${priorSubChunkIndex}) != endSubChunk (${endSubChunk})`,\n );\n }\n callback(\n entryLod,\n entryRow,\n priorSubChunkIndex,\n endSubChunk,\n entryRenderScale,\n );\n }\n priorSubChunkIndex = endSubChunk + 1;\n return;\n }\n if (priorSubChunkIndex !== numSubChunks && entryRow !== -1) {\n callback(\n entryLod,\n entryRow,\n priorSubChunkIndex,\n numSubChunks,\n entryRenderScale,\n );\n }\n priorSubChunkIndex = entrySubChunkIndex + 1;\n --stackDepth;\n }\n }\n\n let priorMissingLod = 0;\n if (DEBUG_CHUNKS_TO_DRAW) {\n console.log(\"\");\n console.log(\"Starting to draw\");\n }\n const { octree } = manifest;\n getDesiredMultiscaleMeshChunks(\n manifest,\n modelViewProjection,\n clippingPlanes,\n detailCutoff,\n viewportWidth,\n viewportHeight,\n (lod, row, renderScale, empty) => {\n if (!empty && !hasChunk(lod, row, renderScale)) {\n priorMissingLod = Math.max(lod, priorMissingLod);\n return;\n }\n if (lod < priorMissingLod) {\n // A parent chunk (containing chunk at coarser level-of-detail) is missing. We can't draw\n // chunks at this level-of-detail because we would not be able to fill in gaps.\n return;\n }\n priorMissingLod = 0;\n const rowOffset = row * 5;\n const x = octree[rowOffset];\n const y = octree[rowOffset + 1];\n const z = octree[rowOffset + 2];\n const subChunkIndex = getOctreeChildIndex(x, y, z);\n const stackIndex = maxLod - lod;\n emitChunksUpTo(stackIndex, subChunkIndex);\n const stackOffset = stackIndex * stackEntryStride;\n stack[stackOffset] = empty ? -1 : row;\n stack[stackOffset + 1] = subChunkIndex;\n stack[stackOffset + 2] = renderScale;\n if (DEBUG_CHUNKS_TO_DRAW) {\n console.log(\n `Adding to stack: lod=${lod}, row=${stack[stackOffset]}, subChunkIndex=${subChunkIndex}`,\n );\n }\n priorSubChunkIndex = 0;\n stackDepth = stackIndex + 1;\n },\n );\n\n emitChunksUpTo(0, 0);\n}\n\nexport function validateOctree(octree: Uint32Array) {\n if (octree.length % 5 !== 0) {\n throw new Error(\"Invalid length\");\n }\n const numNodes = octree.length / 5;\n const seenNodes = new Set();\n function exploreNode(node: number) {\n if (seenNodes.has(node)) {\n throw new Error(\"Previously seen node\");\n }\n seenNodes.add(node);\n if (node < 0 || node >= numNodes) {\n throw new Error(\"Invalid node reference\");\n }\n const x = octree[node * 5];\n const y = octree[node * 5 + 1];\n const z = octree[node * 5 + 2];\n const beginChild = octree[node * 5 + 3];\n const endChild = octree[node * 5 + 4];\n if (\n beginChild < 0 ||\n endChild < 0 ||\n endChild < beginChild ||\n endChild > numNodes ||\n beginChild + 8 < endChild\n ) {\n throw new Error(\"Invalid child references\");\n }\n for (let child = beginChild; child < endChild; ++child) {\n const childX = octree[child * 5];\n const childY = octree[child * 5 + 1];\n const childZ = octree[child * 5 + 2];\n if (childX >>> 1 !== x || childY >>> 1 !== y || childZ >>> 1 !== z) {\n throw new Error(\"invalid child\");\n }\n exploreNode(child);\n }\n }\n if (numNodes === 0) return;\n exploreNode(numNodes - 1);\n if (seenNodes.size !== numNodes) {\n throw new Error(\"Orphan nodes in octree\");\n }\n}\n\nexport function getMultiscaleFragmentKey(\n objectKey: string,\n lod: number,\n chunkIndex: number,\n) {\n return `${objectKey}/${lod}:${chunkIndex}`;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { VisibleLayerInfo } from \"#src/layer/index.js\";\nimport type { PerspectivePanel } from \"#src/perspective_view/panel.js\";\nimport type {\n ThreeDimensionalReadyRenderContext,\n ThreeDimensionalRenderContext,\n} from \"#src/renderlayer.js\";\nimport { VisibilityTrackedRenderLayer } from \"#src/renderlayer.js\";\nimport type { vec3 } from \"#src/util/geom.js\";\nimport type { ShaderBuilder, ShaderModule } from \"#src/webgl/shader.js\";\nimport type { SharedObject } from \"#src/worker_rpc.js\";\n\nexport type PerspectiveViewReadyRenderContext =\n ThreeDimensionalReadyRenderContext;\n\nexport interface PerspectiveViewRenderContext\n extends PerspectiveViewReadyRenderContext,\n ThreeDimensionalRenderContext {\n lightDirection: vec3;\n ambientLighting: number;\n directionalLighting: number;\n emitter: ShaderModule;\n\n /**\n * Specifies whether the emitted color value will be used.\n */\n emitColor: boolean;\n\n /**\n * Specifies whether the emitted pick ID will be used.\n */\n emitPickID: boolean;\n\n /**\n * Specifies whether there was a previous pick ID pass.\n */\n alreadyEmittedPickID: boolean;\n\n /**\n * Specifies the ID of the depth frame buffer texture to query during rendering.\n */\n depthBufferTexture?: WebGLTexture | null;\n\n /**\n * Specifies if there are any slice views\n */\n sliceViewsPresent: boolean;\n\n /**\n * Specifies if the camera is moving\n */\n isContinuousCameraMotionInProgress: boolean;\n\n /**\n * Specifices how to bind the max projection buffer\n */\n bindMaxProjectionBuffer?: () => void | undefined;\n\n /**\n * Specifies how to bind the volume rendering buffer\n */\n bindVolumeRenderingBuffer?: () => void | undefined;\n\n /**\n * Specifies how to assign the max projection emitter\n */\n maxProjectionEmit?: (builder: ShaderBuilder) => void | undefined;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-declaration-merging\nexport class PerspectiveViewRenderLayer<\n AttachmentState = unknown,\n> extends VisibilityTrackedRenderLayer {\n draw(\n renderContext: PerspectiveViewRenderContext,\n attachment: VisibleLayerInfo,\n ): void {\n renderContext;\n attachment;\n // Must be overridden by subclasses.\n }\n\n isReady(\n renderContext: PerspectiveViewReadyRenderContext,\n attachment: VisibleLayerInfo,\n ) {\n renderContext;\n attachment;\n return true;\n }\n\n get transparentPickEnabled() {\n return true;\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport interface PerspectiveViewRenderLayer {\n isTransparent: boolean | undefined;\n isAnnotation: boolean | undefined;\n backend: SharedObject | undefined;\n isVolumeRendering: boolean | undefined;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { hashCombine } from \"#src/gpu_hash/hash_function.js\";\nimport { getRandomValues } from \"#src/util/random.js\";\nimport { Uint64 } from \"#src/util/uint64.js\";\n\nexport const NUM_ALTERNATIVES = 3;\n\n// For 3 hash functions, a DEFAULT_LOAD_FACTOR of 0.8 reliably avoids\n// expensive rehashing caused by unresolvable collisions.\nconst DEFAULT_LOAD_FACTOR = 0.8;\n\nconst DEBUG = false;\n\n// Key that needs to be inserted. Temporary variables used during insert. These can safely be\n// global because control never leaves functions defined in this module while these are in use.\nlet pendingLow = 0;\nlet pendingHigh = 0;\nlet backupPendingLow = 0;\nlet backupPendingHigh = 0;\n\nexport abstract class HashTableBase {\n loadFactor = DEFAULT_LOAD_FACTOR;\n size = 0;\n table: Uint32Array;\n tableSize: number;\n emptyLow = 4294967295;\n emptyHigh = 4294967295;\n maxRehashAttempts = 5;\n maxAttempts = 5;\n capacity: number;\n\n /**\n * Number of uint32 elements per entry in hash table.\n */\n entryStride: number;\n\n generation = 0;\n\n mungedEmptyKey = -1;\n\n constructor(\n public hashSeeds = HashTableBase.generateHashSeeds(NUM_ALTERNATIVES),\n ) {\n // Minimum size must be greater than 2 * hashSeeds.length. Otherwise, tableWithMungedEmptyKey\n // may loop infinitely.\n let initialSize = 8;\n while (initialSize < 2 * hashSeeds.length) {\n initialSize *= 2;\n }\n this.allocate(initialSize);\n }\n\n private updateHashFunctions(numHashes: number) {\n this.hashSeeds = HashTableBase.generateHashSeeds(numHashes);\n this.mungedEmptyKey = -1;\n }\n\n /**\n * Invokes callback with a modified version of the hash table data array.\n *\n * Replaces all slots that appear to be valid entries for (emptyLow, emptyHigh), i.e. slots that\n * contain (emptyLow, emptyHigh) and to which (emptyLow, emptyHigh) hashes, with (mungedEmptyKey,\n * mungedEmptyKey).\n *\n * mungedEmptyKey is chosen to be a 32-bit value with the property that the 64-bit value\n * (mungedEmptyKey, mungedEmptyKey) does not hash to any of the same slots as (emptyLow,\n * emptyHigh).\n *\n * This allows the modified data array to be used for lookups without special casing the empty\n * key.\n */\n tableWithMungedEmptyKey(callback: (table: Uint32Array) => void) {\n const numHashes = this.hashSeeds.length;\n const emptySlots = new Array(numHashes);\n for (let i = 0; i < numHashes; ++i) {\n emptySlots[i] = this.getHash(i, this.emptyLow, this.emptyHigh);\n }\n let { mungedEmptyKey } = this;\n if (mungedEmptyKey === -1) {\n chooseMungedEmptyKey: while (true) {\n mungedEmptyKey = (Math.random() * 0x1000000) >>> 0;\n for (let i = 0; i < numHashes; ++i) {\n const h = this.getHash(i, mungedEmptyKey, mungedEmptyKey);\n for (let j = 0; j < numHashes; ++j) {\n if (emptySlots[j] === h) {\n continue chooseMungedEmptyKey;\n }\n }\n }\n this.mungedEmptyKey = mungedEmptyKey;\n break;\n }\n }\n const { table, emptyLow, emptyHigh } = this;\n for (let i = 0; i < numHashes; ++i) {\n const h = emptySlots[i];\n if (table[h] === emptyLow && table[h + 1] === emptyHigh) {\n table[h] = mungedEmptyKey;\n table[h + 1] = mungedEmptyKey;\n }\n }\n try {\n callback(table);\n } finally {\n for (let i = 0; i < numHashes; ++i) {\n const h = emptySlots[i];\n if (table[h] === mungedEmptyKey && table[h + 1] === mungedEmptyKey) {\n table[h] = emptyLow;\n table[h + 1] = emptyHigh;\n }\n }\n }\n }\n\n static generateHashSeeds(numAlternatives = NUM_ALTERNATIVES) {\n return getRandomValues(new Uint32Array(numAlternatives));\n }\n\n getHash(hashIndex: number, low: number, high: number) {\n let hash = this.hashSeeds[hashIndex];\n hash = hashCombine(hash, low);\n hash = hashCombine(hash, high);\n return this.entryStride * (hash & (this.tableSize - 1));\n }\n\n /**\n * Iterates over the Uint64 keys contained in the hash set.\n *\n * Creates a new Uint64 object at every iteration (otherwise spread and Array.from() fail)\n */\n *keys(): IterableIterator {\n const { emptyLow, emptyHigh, entryStride } = this;\n const { table } = this;\n for (let i = 0, length = table.length; i < length; i += entryStride) {\n const low = table[i];\n const high = table[i + 1];\n if (low !== emptyLow || high !== emptyHigh) {\n yield new Uint64(low, high);\n }\n }\n }\n\n /**\n * Iterates over the Uint64 keys contained in the hash set.\n *\n * The same temp value will be modified and yielded at every iteration.\n */\n *unsafeKeys(temp = new Uint64()): IterableIterator {\n const { emptyLow, emptyHigh, entryStride } = this;\n const { table } = this;\n for (let i = 0, length = table.length; i < length; i += entryStride) {\n const low = table[i];\n const high = table[i + 1];\n if (low !== emptyLow || high !== emptyHigh) {\n temp.low = low;\n temp.high = high;\n yield temp;\n }\n }\n }\n\n indexOfPair(low: number, high: number) {\n const { table, emptyLow, emptyHigh } = this;\n if (low === emptyLow && high === emptyHigh) {\n return -1;\n }\n for (let i = 0, numHashes = this.hashSeeds.length; i < numHashes; ++i) {\n const h = this.getHash(i, low, high);\n if (table[h] === low && table[h + 1] === high) {\n return h;\n }\n }\n return -1;\n }\n\n /**\n * Returns the offset into the hash table of the specified element, or -1 if the element is not\n * present.\n */\n indexOf(x: Uint64) {\n return this.indexOfPair(x.low, x.high);\n }\n\n /**\n * Changes the empty key to a value that is not equal to the current empty key and is not present\n * in the table.\n *\n * This is called when an attempt is made to insert the empty key.\n */\n private chooseAnotherEmptyKey() {\n const { emptyLow, emptyHigh, table, entryStride } = this;\n let newLow: number;\n let newHigh: number;\n while (true) {\n newLow = (Math.random() * 0x100000000) >>> 0;\n newHigh = (Math.random() * 0x100000000) >>> 0;\n if (newLow === emptyLow && newHigh === emptyHigh) {\n continue;\n }\n if (this.hasPair(newLow, newHigh)) {\n continue;\n }\n break;\n }\n\n this.emptyLow = newLow;\n this.emptyHigh = newHigh;\n\n // Replace empty keys in the table.\n for (let h = 0, length = table.length; h < length; h += entryStride) {\n if (table[h] === emptyLow && table[h + 1] === emptyHigh) {\n table[h] = newLow;\n table[h + 1] = newHigh;\n }\n }\n }\n\n /**\n * Returns true iff the specified element is present.\n */\n has(x: Uint64) {\n return this.indexOf(x) !== -1;\n }\n\n /**\n * Returns true iff the specified element is present.\n */\n hasPair(low: number, high: number) {\n return this.indexOfPair(low, high) !== -1;\n }\n\n delete(x: Uint64) {\n const index = this.indexOf(x);\n if (index !== -1) {\n const { table } = this;\n table[index] = this.emptyLow;\n table[index + 1] = this.emptyHigh;\n ++this.generation;\n this.size--;\n return true;\n }\n return false;\n }\n\n private clearTable() {\n const { table, entryStride, emptyLow, emptyHigh } = this;\n const length = table.length;\n\n for (let h = 0; h < length; h += entryStride) {\n table[h] = emptyLow;\n table[h + 1] = emptyHigh;\n }\n }\n\n clear() {\n if (this.size === 0) {\n return false;\n }\n this.size = 0;\n ++this.generation;\n this.clearTable();\n return true;\n }\n\n reserve(x: number) {\n if (x > this.capacity) {\n this.backupPending();\n this.grow(x);\n this.restorePending();\n return true;\n }\n return false;\n }\n\n protected swapPending(table: Uint32Array, offset: number) {\n const tempLow = pendingLow;\n const tempHigh = pendingHigh;\n this.storePending(table, offset);\n table[offset] = tempLow;\n table[offset + 1] = tempHigh;\n }\n\n protected storePending(table: Uint32Array, offset: number) {\n pendingLow = table[offset];\n pendingHigh = table[offset + 1];\n }\n\n protected backupPending() {\n backupPendingLow = pendingLow;\n backupPendingHigh = pendingHigh;\n }\n\n protected restorePending() {\n pendingLow = backupPendingLow;\n pendingHigh = backupPendingHigh;\n }\n\n private tryToInsert() {\n if (DEBUG) {\n console.log(`tryToInsert: ${pendingLow}, ${pendingHigh}`);\n }\n let attempt = 0;\n const { emptyLow, emptyHigh, maxAttempts, table } = this;\n const numHashes = this.hashSeeds.length;\n\n let tableIndex = Math.floor(Math.random() * numHashes);\n while (true) {\n const h = this.getHash(tableIndex, pendingLow, pendingHigh);\n this.swapPending(table, h);\n if (pendingLow === emptyLow && pendingHigh === emptyHigh) {\n return true;\n }\n if (++attempt === maxAttempts) {\n break;\n }\n tableIndex =\n (tableIndex + Math.floor(Math.random() * (numHashes - 1)) + 1) %\n numHashes;\n }\n return false;\n }\n\n private allocate(tableSize: number) {\n this.tableSize = tableSize;\n const { entryStride } = this;\n this.table = new Uint32Array(tableSize * entryStride);\n this.maxAttempts = tableSize;\n this.clearTable();\n this.capacity = tableSize * this.loadFactor;\n this.mungedEmptyKey = -1;\n }\n\n private rehash(oldTable: Uint32Array, tableSize: number) {\n if (DEBUG) {\n console.log(\"rehash begin\");\n }\n this.allocate(tableSize);\n this.updateHashFunctions(this.hashSeeds.length);\n const { emptyLow, emptyHigh, entryStride } = this;\n for (let h = 0, length = oldTable.length; h < length; h += entryStride) {\n const low = oldTable[h];\n const high = oldTable[h + 1];\n if (low !== emptyLow || high !== emptyHigh) {\n this.storePending(oldTable, h);\n if (!this.tryToInsert()) {\n if (DEBUG) {\n console.log(\"rehash failed\");\n }\n return false;\n }\n }\n }\n if (DEBUG) {\n console.log(\"rehash end\");\n }\n return true;\n }\n\n private grow(desiredTableSize: number) {\n if (DEBUG) {\n console.log(`grow: ${desiredTableSize}`);\n }\n const oldTable = this.table;\n let { tableSize } = this;\n while (tableSize < desiredTableSize) {\n tableSize *= 2;\n }\n while (true) {\n for (\n let rehashAttempt = 0;\n rehashAttempt < this.maxRehashAttempts;\n ++rehashAttempt\n ) {\n if (this.rehash(oldTable, tableSize)) {\n if (DEBUG) {\n console.log(\"grow end\");\n }\n return;\n }\n }\n tableSize *= 2;\n }\n }\n\n protected insertInternal() {\n ++this.generation;\n\n if (pendingLow === this.emptyLow && pendingHigh === this.emptyHigh) {\n this.chooseAnotherEmptyKey();\n }\n\n if (++this.size > this.capacity) {\n this.backupPending();\n this.grow(this.tableSize * 2);\n this.restorePending();\n }\n\n while (!this.tryToInsert()) {\n this.backupPending();\n this.grow(this.tableSize);\n this.restorePending();\n }\n }\n}\n\nexport class HashSetUint64 extends HashTableBase {\n add(x: Uint64) {\n const { low, high } = x;\n if (this.hasPair(low, high)) {\n return false;\n }\n if (DEBUG) {\n console.log(`add: ${low},${high}`);\n }\n pendingLow = low;\n pendingHigh = high;\n this.insertInternal();\n return true;\n }\n\n /**\n * Iterates over the keys.\n * Creates a new Uint64 object at every iteration (otherwise spread and Array.from() fail)\n */\n [Symbol.iterator]() {\n return this.unsafeKeys();\n }\n}\nHashSetUint64.prototype.entryStride = 2;\n\n// Value that needs to be inserted. Temporary variables used during insert. These can safely be\n// global because control never leaves functions defined in this module while these are in use.\nlet pendingValueLow = 0;\nlet pendingValueHigh = 0;\nlet backupPendingValueLow = 0;\nlet backupPendingValueHigh = 0;\n\nexport class HashMapUint64 extends HashTableBase {\n set(key: Uint64, value: Uint64) {\n const { low, high } = key;\n if (this.hasPair(low, high)) {\n return false;\n }\n if (DEBUG) {\n console.log(`add: ${low},${high} -> ${value.low},${value.high}`);\n }\n pendingLow = low;\n pendingHigh = high;\n pendingValueLow = value.low;\n pendingValueHigh = value.high;\n this.insertInternal();\n return true;\n }\n\n get(key: Uint64, value: Uint64): boolean {\n const h = this.indexOf(key);\n if (h === -1) {\n return false;\n }\n const { table } = this;\n value.low = table[h + 2];\n value.high = table[h + 3];\n return true;\n }\n\n protected swapPending(table: Uint32Array, offset: number) {\n const tempLow = pendingValueLow;\n const tempHigh = pendingValueHigh;\n super.swapPending(table, offset);\n table[offset + 2] = tempLow;\n table[offset + 3] = tempHigh;\n }\n\n protected storePending(table: Uint32Array, offset: number) {\n super.storePending(table, offset);\n pendingValueLow = table[offset + 2];\n pendingValueHigh = table[offset + 3];\n }\n\n protected backupPending() {\n super.backupPending();\n backupPendingValueLow = pendingValueLow;\n backupPendingValueHigh = pendingValueHigh;\n }\n\n protected restorePending() {\n super.restorePending();\n pendingValueLow = backupPendingValueLow;\n pendingValueHigh = backupPendingValueHigh;\n }\n\n /**\n * Iterates over entries. The same temporary value will be modified and yielded at every\n * iteration.\n */\n [Symbol.iterator]() {\n return this.unsafeEntries();\n }\n\n /**\n * Iterates over entries.\n * Creates new Uint64 objects at every iteration (otherwise spread and Array.from() fail)\n */\n *entries() {\n const { emptyLow, emptyHigh, entryStride } = this;\n const { table } = this;\n for (let i = 0, length = table.length; i < length; i += entryStride) {\n const low = table[i];\n const high = table[i + 1];\n if (low !== emptyLow || high !== emptyHigh) {\n const key = new Uint64(low, high);\n const value = new Uint64(table[i + 2], table[i + 3]);\n yield [key, value];\n }\n }\n }\n\n /**\n * Iterates over entries. The same temporary value will be modified and yielded at every\n * iteration.\n */\n *unsafeEntries(temp: [Uint64, Uint64] = [new Uint64(), new Uint64()]) {\n const { emptyLow, emptyHigh, entryStride } = this;\n const { table } = this;\n const [key, value] = temp;\n for (let i = 0, length = table.length; i < length; i += entryStride) {\n const low = table[i];\n const high = table[i + 1];\n if (low !== emptyLow || high !== emptyHigh) {\n key.low = low;\n key.high = high;\n value.low = table[i + 2];\n value.high = table[i + 3];\n yield temp;\n }\n }\n }\n}\nHashMapUint64.prototype.entryStride = 4;\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file\n * Facilities for reading various data types from 2-D and 3-D WebGL textures.\n *\n * WebGL2 only supports 2-D and 3-D textures, and because implementations typically limit the size\n * of each dimension, a large 1-D array has to be fit to a rectangular 2-D texture, which may\n * require padding.\n */\n\nimport type { TypedArray, TypedArrayConstructor } from \"#src/util/array.js\";\nimport { maybePadArray } from \"#src/util/array.js\";\nimport { DATA_TYPE_SIGNED, DataType } from \"#src/util/data_type.js\";\nimport type { vec3 } from \"#src/util/geom.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type {\n ShaderBuilder,\n ShaderCodePart,\n ShaderSamplerPrefix,\n} from \"#src/webgl/shader.js\";\nimport {\n getShaderType,\n glsl_float,\n glsl_int16,\n glsl_int32,\n glsl_int8,\n glsl_log2Exact,\n glsl_uint16,\n glsl_uint32,\n glsl_uint64,\n glsl_uint8,\n glsl_unpackUint64leFromUint32,\n} from \"#src/webgl/shader_lib.js\";\nimport {\n setRawTexture3DParameters,\n setRawTextureParameters,\n} from \"#src/webgl/texture.js\";\n\nexport type TextureAccessCoefficients = vec3;\n\nexport class TextureFormat {\n /**\n * Number of texels per multi-channel element.\n */\n texelsPerElement: number;\n\n /**\n * Texture internal format to specify when uploading the texture data.\n */\n textureInternalFormat: number;\n\n /**\n * Texture format to specify when uploading the texture data.\n */\n textureFormat: number;\n\n /**\n * Texel type to specify when uploading the texture data.\n */\n texelType: number;\n\n /**\n * Number of typed array elements per texel.\n */\n arrayElementsPerTexel: number;\n\n /**\n * TypedArray type that must be used when uploading the texture data.\n */\n arrayConstructor: TypedArrayConstructor;\n\n samplerPrefix: ShaderSamplerPrefix;\n}\n\nexport const integerTextureFormatForNumComponents = [\n -1,\n WebGL2RenderingContext.RED_INTEGER,\n WebGL2RenderingContext.RG_INTEGER,\n WebGL2RenderingContext.RGB_INTEGER,\n WebGL2RenderingContext.RGBA_INTEGER,\n];\nexport const floatTextureFormatForNumComponents = [\n -1,\n WebGL2RenderingContext.RED,\n WebGL2RenderingContext.RG,\n WebGL2RenderingContext.RGB,\n WebGL2RenderingContext.RGBA,\n];\nexport const textureSelectorForNumComponents = [\"\", \"r\", \"rg\", \"rgb\", \"rgba\"];\nexport const internalUint8FormatForNumComponents = [\n -1,\n WebGL2RenderingContext.R8UI,\n WebGL2RenderingContext.RG8UI,\n WebGL2RenderingContext.RGB8UI,\n WebGL2RenderingContext.RGBA8UI,\n];\nexport const internalInt8FormatForNumComponents = [\n -1,\n WebGL2RenderingContext.R8I,\n WebGL2RenderingContext.RG8I,\n WebGL2RenderingContext.RGB8I,\n WebGL2RenderingContext.RGBA8I,\n];\nexport const internalUint16FormatForNumComponents = [\n -1,\n WebGL2RenderingContext.R16UI,\n WebGL2RenderingContext.RG16UI,\n WebGL2RenderingContext.RGB16UI,\n WebGL2RenderingContext.RGBA16UI,\n];\nexport const internalInt16FormatForNumComponents = [\n -1,\n WebGL2RenderingContext.R16I,\n WebGL2RenderingContext.RG16I,\n WebGL2RenderingContext.RGB16I,\n WebGL2RenderingContext.RGBA16I,\n];\nexport const internalUint32FormatForNumComponents = [\n -1,\n WebGL2RenderingContext.R32UI,\n WebGL2RenderingContext.RG32UI,\n WebGL2RenderingContext.RGB32UI,\n WebGL2RenderingContext.RGBA32UI,\n];\nexport const internalInt32FormatForNumComponents = [\n -1,\n WebGL2RenderingContext.R32I,\n WebGL2RenderingContext.RG32I,\n WebGL2RenderingContext.RGB32I,\n WebGL2RenderingContext.RGBA32I,\n];\nexport const internalFloatFormatForNumComponents = [\n -1,\n WebGL2RenderingContext.R32F,\n WebGL2RenderingContext.RG32F,\n WebGL2RenderingContext.RGB32F,\n WebGL2RenderingContext.RGBA32F,\n];\n\nexport function getSamplerPrefixForDataType(\n dataType: DataType,\n): ShaderSamplerPrefix {\n return dataType === DataType.FLOAT32\n ? \"\"\n : DATA_TYPE_SIGNED[dataType]\n ? \"i\"\n : \"u\";\n}\n\n/**\n * Fills in a OneDimensionalTextureFormat object with the suitable texture format for the specified\n * DataType and number of components.\n */\nexport function computeTextureFormat(\n format: TextureFormat,\n dataType: DataType,\n numComponents = 1,\n) {\n switch (dataType) {\n case DataType.UINT8:\n if (numComponents < 1 || numComponents > 4) {\n break;\n }\n format.texelsPerElement = 1;\n format.textureInternalFormat =\n internalUint8FormatForNumComponents[numComponents];\n format.textureFormat =\n integerTextureFormatForNumComponents[numComponents];\n format.texelType = WebGL2RenderingContext.UNSIGNED_BYTE;\n format.arrayElementsPerTexel = numComponents;\n format.arrayConstructor = Uint8Array;\n format.samplerPrefix = \"u\";\n return format;\n case DataType.INT8:\n if (numComponents < 1 || numComponents > 4) {\n break;\n }\n format.texelsPerElement = 1;\n format.textureInternalFormat =\n internalInt8FormatForNumComponents[numComponents];\n format.textureFormat =\n integerTextureFormatForNumComponents[numComponents];\n format.texelType = WebGL2RenderingContext.BYTE;\n format.arrayElementsPerTexel = numComponents;\n format.arrayConstructor = Int8Array;\n format.samplerPrefix = \"i\";\n return format;\n case DataType.UINT16:\n if (numComponents < 1 || numComponents > 4) {\n break;\n }\n format.texelsPerElement = 1;\n format.textureInternalFormat =\n internalUint16FormatForNumComponents[numComponents];\n format.textureFormat =\n integerTextureFormatForNumComponents[numComponents];\n format.texelType = WebGL2RenderingContext.UNSIGNED_SHORT;\n format.arrayElementsPerTexel = numComponents;\n format.arrayConstructor = Uint16Array;\n format.samplerPrefix = \"u\";\n return format;\n case DataType.INT16:\n if (numComponents < 1 || numComponents > 4) {\n break;\n }\n format.texelsPerElement = 1;\n format.textureInternalFormat =\n internalInt16FormatForNumComponents[numComponents];\n format.textureFormat =\n integerTextureFormatForNumComponents[numComponents];\n format.texelType = WebGL2RenderingContext.SHORT;\n format.arrayElementsPerTexel = numComponents;\n format.arrayConstructor = Int16Array;\n format.samplerPrefix = \"i\";\n return format;\n case DataType.UINT32:\n if (numComponents < 1 || numComponents > 4) {\n break;\n }\n format.texelsPerElement = 1;\n format.textureInternalFormat =\n internalUint32FormatForNumComponents[numComponents];\n format.textureFormat =\n integerTextureFormatForNumComponents[numComponents];\n format.texelType = WebGL2RenderingContext.UNSIGNED_INT;\n format.arrayElementsPerTexel = 1;\n format.arrayConstructor = Uint32Array;\n format.samplerPrefix = \"u\";\n return format;\n case DataType.INT32:\n if (numComponents < 1 || numComponents > 4) {\n break;\n }\n format.texelsPerElement = 1;\n format.textureInternalFormat =\n internalInt32FormatForNumComponents[numComponents];\n format.textureFormat =\n integerTextureFormatForNumComponents[numComponents];\n format.texelType = WebGL2RenderingContext.INT;\n format.arrayElementsPerTexel = 1;\n format.arrayConstructor = Int32Array;\n format.samplerPrefix = \"i\";\n return format;\n case DataType.UINT64:\n if (numComponents < 1 || numComponents > 2) {\n break;\n }\n format.texelsPerElement = 1;\n format.textureInternalFormat =\n internalUint32FormatForNumComponents[numComponents * 2];\n format.textureFormat =\n integerTextureFormatForNumComponents[numComponents * 2];\n format.texelType = WebGL2RenderingContext.UNSIGNED_INT;\n format.arrayElementsPerTexel = 2 * numComponents;\n format.arrayConstructor = Uint32Array;\n format.samplerPrefix = \"u\";\n return format;\n case DataType.FLOAT32:\n if (numComponents < 1 || numComponents > 4) {\n break;\n }\n format.texelsPerElement = 1;\n format.textureInternalFormat =\n internalFloatFormatForNumComponents[numComponents];\n format.textureFormat = floatTextureFormatForNumComponents[numComponents];\n format.texelType = WebGL2RenderingContext.FLOAT;\n format.arrayElementsPerTexel = numComponents;\n format.arrayConstructor = Float32Array;\n format.samplerPrefix = \"\";\n return format;\n }\n throw new Error(\n `No supported texture format for ${DataType[dataType]}[${numComponents}].`,\n );\n}\n\nexport function setOneDimensionalTextureData(\n gl: GL,\n format: TextureFormat,\n data: TypedArray,\n) {\n const {\n arrayConstructor,\n arrayElementsPerTexel,\n textureInternalFormat,\n textureFormat,\n texelsPerElement,\n } = format;\n const { maxTextureSize } = gl;\n const numElements = data.length / arrayElementsPerTexel;\n if (numElements * texelsPerElement > maxTextureSize * maxTextureSize) {\n throw new Error(\n \"Number of elements exceeds maximum texture size: \" +\n texelsPerElement +\n \" * \" +\n numElements,\n );\n }\n const minX = Math.ceil(numElements / maxTextureSize);\n const textureXBits = Math.ceil(Math.log2(minX));\n const textureWidth = (1 << textureXBits) * texelsPerElement;\n const textureHeight = Math.ceil(numElements / (1 << textureXBits));\n const requiredSize = textureWidth * textureHeight * arrayElementsPerTexel;\n if (data.constructor !== arrayConstructor) {\n data = new arrayConstructor(\n data.buffer,\n data.byteOffset,\n data.byteLength / arrayConstructor.BYTES_PER_ELEMENT,\n );\n }\n const padded = maybePadArray(data, requiredSize);\n gl.pixelStorei(WebGL2RenderingContext.UNPACK_ALIGNMENT, 1);\n setRawTextureParameters(gl);\n gl.texImage2D(\n WebGL2RenderingContext.TEXTURE_2D,\n /*level=*/ 0,\n textureInternalFormat,\n /*width=*/ textureWidth,\n /*height=*/ textureHeight,\n /*border=*/ 0,\n textureFormat,\n format.texelType,\n padded,\n );\n}\n\nexport function setTwoDimensionalTextureData(\n gl: GL,\n format: TextureFormat,\n data: TypedArray,\n width: number,\n height: number,\n) {\n const {\n arrayConstructor,\n textureInternalFormat,\n textureFormat,\n texelsPerElement,\n } = format;\n if (data.constructor !== arrayConstructor) {\n data = new arrayConstructor(\n data.buffer,\n data.byteOffset,\n data.byteLength / arrayConstructor.BYTES_PER_ELEMENT,\n );\n }\n gl.pixelStorei(WebGL2RenderingContext.UNPACK_ALIGNMENT, 1);\n setRawTextureParameters(gl);\n gl.texImage2D(\n WebGL2RenderingContext.TEXTURE_2D,\n /*level=*/ 0,\n textureInternalFormat,\n /*width=*/ width * texelsPerElement,\n /*height=*/ height,\n /*border=*/ 0,\n textureFormat,\n format.texelType,\n data,\n );\n}\n\nexport function setThreeDimensionalTextureData(\n gl: GL,\n format: TextureFormat,\n data: TypedArray,\n width: number,\n height: number,\n depth: number,\n) {\n const {\n arrayConstructor,\n textureInternalFormat,\n textureFormat,\n texelsPerElement,\n } = format;\n if (data.constructor !== arrayConstructor) {\n data = new arrayConstructor(\n data.buffer,\n data.byteOffset,\n data.byteLength / arrayConstructor.BYTES_PER_ELEMENT,\n );\n }\n gl.pixelStorei(WebGL2RenderingContext.UNPACK_ALIGNMENT, 1);\n setRawTexture3DParameters(gl);\n gl.texImage3D(\n WebGL2RenderingContext.TEXTURE_3D,\n /*level=*/ 0,\n textureInternalFormat,\n /*width=*/ width * texelsPerElement,\n /*height=*/ height,\n /*depth=*/ depth,\n /*border=*/ 0,\n textureFormat,\n format.texelType,\n data,\n );\n}\n\nfunction getShaderCodeForDataType(dataType: DataType): ShaderCodePart {\n switch (dataType) {\n case DataType.UINT8:\n return glsl_uint8;\n case DataType.INT8:\n return glsl_int8;\n case DataType.UINT16:\n return glsl_uint16;\n case DataType.INT16:\n return glsl_int16;\n case DataType.UINT32:\n return glsl_uint32;\n case DataType.INT32:\n return glsl_int32;\n case DataType.UINT64:\n return glsl_uint64;\n case DataType.FLOAT32:\n return glsl_float;\n }\n}\n\nfunction getAccessorFunction(\n functionName: string,\n readTextureValue: string,\n samplerName: string,\n indexType: string,\n dataType: DataType,\n numComponents: number,\n): ShaderCodePart[] {\n const shaderType = getShaderType(dataType, numComponents);\n const parts: ShaderCodePart[] = [getShaderCodeForDataType(dataType)];\n let code = `\n${shaderType} ${functionName}(${indexType} index) {\n`;\n switch (dataType) {\n case DataType.UINT8:\n case DataType.UINT16:\n case DataType.UINT32:\n code += `\n ${shaderType} result;\n highp uvec4 temp;\n ${readTextureValue}(${samplerName}, index, temp);\n result.value = temp.${textureSelectorForNumComponents[numComponents]};\n return result;\n`;\n break;\n case DataType.INT8:\n case DataType.INT16:\n case DataType.INT32:\n code += `\n ${shaderType} result;\n highp ivec4 temp;\n ${readTextureValue}(${samplerName}, index, temp);\n result.value = temp.${textureSelectorForNumComponents[numComponents]};\n return result;\n`;\n break;\n case DataType.UINT64:\n parts.push(glsl_unpackUint64leFromUint32);\n code += `\n highp uvec4 temp;\n ${readTextureValue}(${samplerName}, index, temp);\n return unpackUint64leFromUint32(temp.${\n textureSelectorForNumComponents[numComponents * 2]\n });\n`;\n break;\n case DataType.FLOAT32:\n parts.push(glsl_float);\n code += `\n highp vec4 temp;\n ${readTextureValue}(${samplerName}, index, temp);\n return temp.${textureSelectorForNumComponents[numComponents]};\n`;\n break;\n }\n code += `\n}\n`;\n parts.push(code);\n return parts;\n}\n\nexport class OneDimensionalTextureAccessHelper {\n readTextureValue = `readTextureValue_${this.key}`;\n constructor(public key: string) {}\n defineShader(builder: ShaderBuilder) {\n builder;\n }\n\n getReadTextureValueCode(\n texelsPerElement: number,\n samplerPrefix: ShaderSamplerPrefix,\n ) {\n let code = `\nvoid ${this.readTextureValue}(highp ${samplerPrefix}sampler2D sampler, highp uint index`;\n for (let i = 0; i < texelsPerElement; ++i) {\n code += `, out ${samplerPrefix}vec4 output${i}`;\n }\n code += `) {\n highp int width = textureSize(sampler, 0).x / ${texelsPerElement};\n highp uint log2width = log2Exact(uint(width));\n highp int y = int(index >> log2width);\n highp int x = int((index - (uint(y) << log2width)) * ${texelsPerElement}u);\n`;\n for (let i = 0; i < texelsPerElement; ++i) {\n code += `\n output${i} = texelFetch(sampler, ivec2(x + ${i}, y), 0);\n`;\n }\n code += `\n}\n`;\n return [glsl_log2Exact, code];\n }\n\n getAccessor(\n functionName: string,\n samplerName: string,\n dataType: DataType,\n numComponents = 1,\n ) {\n const samplerPrefix = getSamplerPrefixForDataType(dataType);\n return [\n this.getReadTextureValueCode(1, samplerPrefix),\n ...getAccessorFunction(\n functionName,\n this.readTextureValue,\n samplerName,\n \"highp uint\",\n dataType,\n numComponents,\n ),\n ];\n }\n}\n\nexport class TextureAccessHelper {\n readTextureValue = `readTextureValue_${this.key}`;\n constructor(\n public key: string,\n public textureDims: number,\n ) {}\n getReadTextureValueCode(\n texelsPerElement: number,\n samplerPrefix: ShaderSamplerPrefix,\n ) {\n const { textureDims } = this;\n let code = `\nvoid ${this.readTextureValue}(highp ${samplerPrefix}sampler${this.textureDims}D sampler, highp ivec${textureDims} p`;\n for (let i = 0; i < texelsPerElement; ++i) {\n code += `, out ${samplerPrefix}vec4 output${i}`;\n }\n code += `) {\n`;\n for (let i = 0; i < texelsPerElement; ++i) {\n code += `\n output${i} = texelFetch(sampler, ivec${textureDims}(p.x * ${texelsPerElement} + ${i}, p.y\n ${\n textureDims === 3 ? \", p.z\" : \"\"\n }), 0);\n`;\n }\n code += `\n}\n`;\n return code;\n }\n\n getAccessor(\n functionName: string,\n samplerName: string,\n dataType: DataType,\n numComponents = 1,\n ) {\n const samplerPrefix = getSamplerPrefixForDataType(dataType);\n return [\n this.getReadTextureValueCode(1, samplerPrefix),\n ...getAccessorFunction(\n functionName,\n this.readTextureValue,\n samplerName,\n `highp ivec${this.textureDims}`,\n dataType,\n numComponents,\n ),\n ];\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { HashTableBase } from \"#src/gpu_hash/hash_table.js\";\nimport { NUM_ALTERNATIVES } from \"#src/gpu_hash/hash_table.js\";\nimport { DataType } from \"#src/util/data_type.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { ShaderBuilder, ShaderProgram } from \"#src/webgl/shader.js\";\nimport { glsl_equalUint64, glsl_uint64 } from \"#src/webgl/shader_lib.js\";\nimport {\n computeTextureFormat,\n OneDimensionalTextureAccessHelper,\n setOneDimensionalTextureData,\n TextureFormat,\n} from \"#src/webgl/texture_access.js\";\n\n// MumurHash, excluding the final mixing steps.\nexport const glsl_hashCombine = [\n glsl_uint64,\n `\nhighp uint hashCombine(highp uint state, highp uint value) {\n value *= 0xcc9e2d51u;\n value = (value << 15u) | (value >> 17u);\n value *= 0x1b873593u;\n state ^= value;\n state = (state << 13u) | (state >> 19u);\n state = (state * 5u) + 0xe6546b64u;\n return state;\n}\nhighp uint hashCombine(highp uint state, uint64_t x) {\n state = hashCombine(state, x.value[0]);\n return hashCombine(state, x.value[1]);\n}\n`,\n];\n\nconst textureFormat = computeTextureFormat(\n new TextureFormat(),\n DataType.UINT64,\n 1,\n);\n\nexport class GPUHashTable extends RefCounted {\n generation = -1;\n texture: WebGLTexture | null = null;\n\n constructor(\n public gl: GL,\n public hashTable: HashTable,\n ) {\n super();\n // createTexture should never actually return null.\n this.texture = gl.createTexture();\n }\n\n copyToGPU() {\n const { hashTable } = this;\n const { generation } = hashTable;\n if (this.generation === generation) {\n return;\n }\n const { gl, texture } = this;\n this.generation = generation;\n gl.activeTexture(WebGL2RenderingContext.TEXTURE0 + gl.tempTextureUnit);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, texture);\n hashTable.tableWithMungedEmptyKey((table) => {\n setOneDimensionalTextureData(this.gl, textureFormat, table);\n });\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, null);\n }\n\n disposed() {\n const { gl } = this;\n gl.deleteTexture(this.texture);\n this.texture = null;\n this.gl = undefined;\n this.hashTable = undefined;\n super.disposed();\n }\n\n static get(gl: GL, hashTable: HashTable) {\n return gl.memoize.get(hashTable, () => new GPUHashTable(gl, hashTable));\n }\n}\n\nexport class HashSetShaderManager {\n textureUnitSymbol = Symbol.for(`gpuhashtable:${this.prefix}`);\n private accessHelper = new OneDimensionalTextureAccessHelper(\n `gpuhashtable_${this.prefix}`,\n );\n samplerName = this.prefix + \"_sampler\";\n hashSeedsName = this.prefix + \"_seeds\";\n hashKeyMask = this.prefix + \"_keyMask\";\n readTable = this.prefix + \"_readTable\";\n\n constructor(\n public prefix: string,\n public numAlternatives = NUM_ALTERNATIVES,\n ) {}\n\n defineShader(builder: ShaderBuilder) {\n const { hashSeedsName, samplerName, numAlternatives, hashKeyMask } = this;\n builder.addUniform(\"highp uint\", hashSeedsName, numAlternatives);\n builder.addUniform(\"highp uint\", hashKeyMask);\n builder.addTextureSampler(\n \"usampler2D\",\n samplerName,\n this.textureUnitSymbol,\n );\n builder.addFragmentCode(glsl_hashCombine);\n builder.addFragmentCode(glsl_uint64);\n builder.addFragmentCode(glsl_equalUint64);\n this.accessHelper.defineShader(builder);\n builder.addFragmentCode(\n this.accessHelper.getAccessor(\n this.readTable,\n this.samplerName,\n DataType.UINT64,\n 1,\n ),\n );\n let s = \"\";\n s += `\nbool ${this.hasFunctionName}(uint64_t x) {\n`;\n for (let alt = 0; alt < numAlternatives; ++alt) {\n s += `\n {\n uint h = hashCombine(${hashSeedsName}[${alt}], x) & ${hashKeyMask};\n uint64_t key = ${this.readTable}(h);\n if (equals(key, x)) {\n return true;\n }\n }\n`;\n }\n s += `\n return false;\n}\n`;\n builder.addFragmentCode(s);\n }\n\n get hasFunctionName() {\n return `${this.prefix}_has`;\n }\n\n enable(\n gl: GL,\n shader: ShaderProgram,\n hashTable: GPUHashTable,\n ) {\n hashTable.copyToGPU();\n const textureUnit = shader.textureUnit(this.textureUnitSymbol);\n gl.activeTexture(WebGL2RenderingContext.TEXTURE0 + textureUnit);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, hashTable.texture);\n gl.uniform1ui(\n shader.uniform(this.hashKeyMask),\n hashTable.hashTable.tableSize - 1,\n );\n gl.uniform1uiv(\n shader.uniform(this.hashSeedsName),\n hashTable.hashTable.hashSeeds,\n );\n }\n\n disable(gl: GL, shader: ShaderProgram) {\n const textureUnit = shader.textureUnit(this.textureUnitSymbol);\n gl.activeTexture(WebGL2RenderingContext.TEXTURE0 + textureUnit);\n gl.bindTexture(WebGL2RenderingContext.TEXTURE_2D, null);\n }\n}\n\nexport class HashMapShaderManager extends HashSetShaderManager {\n defineShader(builder: ShaderBuilder) {\n super.defineShader(builder);\n const { numAlternatives, hashSeedsName, hashKeyMask } = this;\n let s = `\nbool ${this.getFunctionName}(uint64_t x, out uint64_t value) {\n`;\n for (let alt = 0; alt < numAlternatives; ++alt) {\n s += `\n {\n uint h = hashCombine(${hashSeedsName}[${alt}], x) & ${hashKeyMask};\n uint64_t key = ${this.readTable}(h * 2u);\n if (equals(key, x)) {\n value = ${this.readTable}(h * 2u + 1u);\n return true;\n }\n }\n`;\n }\n s += `\n return false;\n}\n`;\n builder.addFragmentCode(s);\n }\n\n get getFunctionName() {\n return `${this.prefix}_get`;\n }\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { hashCombine } from \"#src/gpu_hash/hash_function.js\";\nimport type { HashTableBase } from \"#src/gpu_hash/hash_table.js\";\nimport type { GPUHashTable } from \"#src/gpu_hash/shader.js\";\nimport {\n glsl_hashCombine,\n HashMapShaderManager,\n} from \"#src/gpu_hash/shader.js\";\nimport { hsvToRgb } from \"#src/util/colorspace.js\";\nimport { getRandomUint32 } from \"#src/util/random.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport type { Trackable } from \"#src/util/trackable.js\";\nimport type { Uint64 } from \"#src/util/uint64.js\";\nimport type { GL } from \"#src/webgl/context.js\";\nimport type { ShaderBuilder, ShaderProgram } from \"#src/webgl/shader.js\";\nimport { glsl_hsvToRgb, glsl_uint64 } from \"#src/webgl/shader_lib.js\";\n\nconst NUM_COMPONENTS = 2;\n\nexport class SegmentColorShaderManager {\n seedName = this.prefix + \"_seed\";\n\n constructor(public prefix: string) {}\n\n defineShader(builder: ShaderBuilder) {\n const { seedName } = this;\n builder.addUniform(\"highp uint\", seedName);\n builder.addFragmentCode(glsl_uint64);\n builder.addFragmentCode(glsl_hashCombine);\n builder.addFragmentCode(glsl_hsvToRgb);\n let s = `\nvec3 ${this.prefix}(uint64_t x) {\n uint h = hashCombine(${seedName}, x);\n vec${NUM_COMPONENTS} v;\n`;\n for (let i = 0; i < NUM_COMPONENTS; ++i) {\n s += `\n v[${i}] = float(h & 0xFFu) / 255.0;\n h >>= 8u;\n`;\n }\n s += `\n vec3 hsv = vec3(v.x, 0.5 + v.y * 0.5, 1.0);\n return hsvToRgb(hsv);\n}\n`;\n builder.addFragmentCode(s);\n }\n\n enable(gl: GL, shader: ShaderProgram, segmentColorHash: number) {\n gl.uniform1ui(shader.uniform(this.seedName), segmentColorHash);\n }\n}\n\nconst tempColor = new Float32Array(3);\n\nexport function getCssColor(color: Float32Array) {\n return `rgb(${color[0] * 100}%,${color[1] * 100}%,${color[2] * 100}%)`;\n}\n\nexport class SegmentColorHash implements Trackable {\n changed = new NullarySignal();\n\n constructor(public hashSeed: number = getRandomUint32()) {}\n\n static getDefault() {\n return new SegmentColorHash(0);\n }\n\n get value() {\n return this.hashSeed;\n }\n\n set value(value: number) {\n if (value !== this.hashSeed) {\n this.hashSeed = value;\n this.changed.dispatch();\n }\n }\n\n compute(out: Float32Array, x: Uint64) {\n let h = hashCombine(this.hashSeed, x.low);\n h = hashCombine(h, x.high);\n const c0 = (h & 0xff) / 255;\n const c1 = ((h >> 8) & 0xff) / 255;\n hsvToRgb(out, c0, 0.5 + 0.5 * c1, 1.0);\n return out;\n }\n\n computeCssColor(x: Uint64) {\n this.compute(tempColor, x);\n return getCssColor(tempColor);\n }\n\n randomize() {\n this.hashSeed = getRandomUint32();\n this.changed.dispatch();\n }\n\n toString() {\n return `new SegmentColorHash(${this.hashSeed})`;\n }\n\n toJSON() {\n return this.hashSeed === 0 ? undefined : this.hashSeed;\n }\n\n reset() {\n this.restoreState(0);\n }\n\n restoreState(x: any) {\n const newSeed = x >>> 0;\n if (newSeed !== this.hashSeed) {\n this.hashSeed = newSeed;\n this.changed.dispatch();\n }\n }\n}\n\n/**\n * Adds the shader code to get a segment's color if it is present in the map.\n */\nexport class SegmentStatedColorShaderManager {\n private hashMapShaderManager = new HashMapShaderManager(\n \"segmentStatedColorHash\",\n );\n\n constructor(public prefix: string) {}\n\n defineShader(builder: ShaderBuilder) {\n this.hashMapShaderManager.defineShader(builder);\n const s = `\nbool ${this.getFunctionName}(uint64_t x, out vec4 value) {\n uint64_t uint64Value;\n if (${this.hashMapShaderManager.getFunctionName}(x, uint64Value)) {\n uint uintValue = uint64Value.value[0];\n value.r = float((uintValue & 0x0000ffu)) / 255.0;\n value.g = float((uintValue & 0x00ff00u) >> 8) / 255.0;\n value.b = float((uintValue & 0xff0000u) >> 16) / 255.0;\n value.a = float((uintValue & 0xff000000u) >> 24) / 255.0;\n return true;\n }\n return false;\n}\n`;\n builder.addFragmentCode(s);\n }\n\n get getFunctionName() {\n return `${this.prefix}_get`;\n }\n\n enable(\n gl: GL,\n shader: ShaderProgram,\n hashTable: GPUHashTable,\n ) {\n this.hashMapShaderManager.enable(gl, shader, hashTable);\n }\n\n disable(gl: GL, shader: ShaderProgram) {\n this.hashMapShaderManager.disable(gl, shader);\n }\n}\n","/**\n * @license\n * Copyright 2017 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { EventActionMap } from \"#src/util/event_action_map.js\";\nimport type { InputEventBindings } from \"#src/viewer.js\";\n\nlet defaultGlobalBindings: EventActionMap | undefined;\n\nexport function getDefaultGlobalBindings() {\n if (defaultGlobalBindings === undefined) {\n const map = new EventActionMap();\n map.set(\"keyl\", \"recolor\");\n map.set(\"keyx\", \"clear-segments\");\n map.set(\"keys\", \"toggle-show-slices\");\n map.set(\"keyb\", \"toggle-scale-bar\");\n map.set(\"keyv\", \"toggle-default-annotations\");\n map.set(\"keya\", \"toggle-axis-lines\");\n map.set(\"keyo\", \"toggle-orthographic-projection\");\n\n for (let i = 1; i <= 9; ++i) {\n map.set(\"digit\" + i, \"toggle-layer-\" + i);\n map.set(\"control+digit\" + i, \"select-layer-\" + i);\n map.set(\"alt+digit\" + i, \"toggle-pick-layer-\" + i);\n }\n\n for (let i = 0; i < 26; ++i) {\n const lowercase = String.fromCharCode(97 + i);\n const uppercase = String.fromCharCode(65 + i);\n map.set(`alt?+control?+shift+key${lowercase}`, `tool-${uppercase}`);\n }\n\n map.set(\"keyn\", \"add-layer\");\n map.set(\"keyh\", \"help\");\n\n map.set(\"space\", \"toggle-layout\");\n map.set(\"shift+space\", \"toggle-layout-alternative\");\n map.set(\"backslash\", \"toggle-show-statistics\");\n\n map.set(\"alt+arrowup\", \"select-previous\");\n map.set(\"alt+arrowdown\", \"select-next\");\n defaultGlobalBindings = map;\n }\n return defaultGlobalBindings;\n}\n\nlet defaultSelectBindings: EventActionMap | undefined;\nexport function getDefaultSelectBindings() {\n if (defaultSelectBindings === undefined) {\n defaultSelectBindings = EventActionMap.fromObject({\n \"control+mousedown2\": \"select-position\",\n });\n }\n return defaultSelectBindings;\n}\n\nlet defaultAnnotationListBindings: EventActionMap | undefined;\nexport function getDefaultAnnotationListBindings() {\n if (defaultAnnotationListBindings === undefined) {\n defaultAnnotationListBindings = EventActionMap.fromObject(\n {\n click0: \"pin-annotation\",\n mousedown2: \"move-to-annotation\",\n },\n { parents: [[getDefaultSelectBindings(), 0]] },\n );\n }\n return defaultAnnotationListBindings;\n}\n\nlet defaultRenderedDataPanelBindings: EventActionMap | undefined;\nexport function getDefaultRenderedDataPanelBindings() {\n if (defaultRenderedDataPanelBindings === undefined) {\n defaultRenderedDataPanelBindings = EventActionMap.fromObject(\n {\n arrowleft: \"x-\",\n arrowright: \"x+\",\n arrowup: \"y-\",\n arrowdown: \"y+\",\n comma: \"z-\",\n period: \"z+\",\n bracketleft: \"t-\",\n bracketright: \"t+\",\n keyz: \"snap\",\n \"control+equal\": \"zoom-in\",\n \"alt+equal\": \"depth-range-decrease\",\n \"control+shift+equal\": \"zoom-in\",\n \"alt+shift+equal\": \"depth-range-decrease\",\n \"control+minus\": \"zoom-out\",\n \"alt+minus\": \"depth-range-increase\",\n keyr: \"rotate-relative-z-\",\n keye: \"rotate-relative-z+\",\n \"shift+arrowdown\": \"rotate-relative-x-\",\n \"shift+arrowup\": \"rotate-relative-x+\",\n \"shift+arrowleft\": \"rotate-relative-y-\",\n \"shift+arrowright\": \"rotate-relative-y+\",\n \"control+wheel\": { action: \"zoom-via-wheel\", preventDefault: true },\n \"alt+wheel\": {\n action: \"adjust-depth-range-via-wheel\",\n preventDefault: true,\n },\n \"at:wheel\": { action: \"z+1-via-wheel\", preventDefault: true },\n \"at:shift+wheel\": { action: \"z+10-via-wheel\", preventDefault: true },\n \"at:dblclick0\": \"select\",\n \"at:shift+dblclick0\": \"star\",\n \"at:control+mousedown0\": \"annotate\",\n \"at:mousedown2\": \"move-to-mouse-position\",\n \"at:alt+mousedown0\": \"move-annotation\",\n \"at:control+alt+mousedown2\": \"delete-annotation\",\n \"at:touchpinch\": \"zoom-via-touchpinch\",\n \"at:touchrotate\": \"rotate-in-plane-via-touchrotate\",\n \"at:touchtranslate2\": \"translate-in-plane-via-touchtranslate\",\n \"at:touchhold1\": \"move-to-mouse-position\",\n \"at:touchtap1x2\": \"select\",\n \"at:touchtap2x3\": \"snap\",\n },\n {\n label: \"All Data Panels\",\n parents: [[getDefaultSelectBindings(), 0]],\n },\n );\n }\n return defaultRenderedDataPanelBindings;\n}\n\nlet defaultPerspectivePanelBindings: EventActionMap | undefined;\nexport function getDefaultPerspectivePanelBindings() {\n if (defaultPerspectivePanelBindings === undefined) {\n defaultPerspectivePanelBindings = EventActionMap.fromObject(\n {\n \"at:mousedown0\": {\n action: \"rotate-via-mouse-drag\",\n stopPropagation: true,\n },\n \"at:shift+mousedown0\": {\n action: \"translate-via-mouse-drag\",\n stopPropagation: true,\n },\n \"at:touchtranslate1\": \"rotate-out-of-plane-via-touchtranslate\",\n },\n {\n parents: [\n [getDefaultRenderedDataPanelBindings(), Number.NEGATIVE_INFINITY],\n ],\n },\n );\n }\n return defaultPerspectivePanelBindings;\n}\n\nlet defaultSliceViewPanelBindings: EventActionMap | undefined;\nexport function getDefaultSliceViewPanelBindings() {\n if (defaultSliceViewPanelBindings === undefined) {\n defaultSliceViewPanelBindings = EventActionMap.fromObject(\n {\n \"at:mousedown0\": {\n action: \"translate-via-mouse-drag\",\n stopPropagation: true,\n },\n \"at:shift+mousedown0\": {\n action: \"rotate-via-mouse-drag\",\n stopPropagation: true,\n },\n \"at:touchtranslate1\": \"translate-z-via-touchtranslate\",\n },\n {\n parents: [\n [getDefaultRenderedDataPanelBindings(), Number.NEGATIVE_INFINITY],\n ],\n },\n );\n }\n return defaultSliceViewPanelBindings;\n}\n\nexport function setDefaultInputEventBindings(\n inputEventBindings: InputEventBindings,\n) {\n inputEventBindings.global.addParent(\n getDefaultGlobalBindings(),\n Number.NEGATIVE_INFINITY,\n );\n inputEventBindings.sliceView.addParent(\n getDefaultSliceViewPanelBindings(),\n Number.NEGATIVE_INFINITY,\n );\n inputEventBindings.perspectiveView.addParent(\n getDefaultPerspectivePanelBindings(),\n Number.NEGATIVE_INFINITY,\n );\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/ui/drag_and_drop.css\";\nimport { filterArrayInplace } from \"#src/util/array.js\";\nimport { removeChildren } from \"#src/util/dom.js\";\n\nlet dragStatusElement: HTMLElement | undefined;\n\nexport type DragStatusRenderer = string | (() => Node);\n\nexport type DragStatusType = \"drag\" | \"drop\";\n\nconst dragStatusStack: {\n target: EventTarget;\n operation: DragStatusType;\n status: DragStatusRenderer;\n}[] = [];\n\nfunction getStatusElement() {\n if (dragStatusElement === undefined) {\n const element = (dragStatusElement = document.createElement(\"div\"));\n element.classList.add(\"neuroglancer-drag-status\");\n document.body.appendChild(element);\n }\n return dragStatusElement;\n}\n\nfunction clearStatus() {\n if (dragStatusElement !== undefined) {\n removeChildren(dragStatusElement);\n dragStatusElement.style.display = \"none\";\n }\n}\n\nfunction applyStatus(status: DragStatusRenderer) {\n const element = getStatusElement();\n removeChildren(element);\n if (typeof status === \"string\") {\n element.appendChild(document.createTextNode(status));\n } else {\n element.appendChild(status());\n }\n element.style.display = \"\";\n}\n\nfunction removeDragStatus(target: EventTarget, operation: DragStatusType) {\n filterArrayInplace(\n dragStatusStack,\n (entry) => !(entry.target === target && entry.operation === operation),\n );\n}\n\nexport function pushDragStatus(\n target: EventTarget,\n operation: DragStatusType,\n status: DragStatusRenderer,\n) {\n removeDragStatus(target, operation);\n dragStatusStack.push({ target, operation, status });\n applyStatus(status);\n}\n\nexport function popDragStatus(target: EventTarget, operation: DragStatusType) {\n removeDragStatus(target, operation);\n const entry =\n dragStatusStack.length === 0\n ? undefined\n : dragStatusStack[dragStatusStack.length - 1];\n if (entry === undefined) {\n clearStatus();\n } else {\n applyStatus(entry.status);\n }\n}\n","/**\n * @license\n * Copyright 2021 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/ui/side_panel.css\";\n\nimport type { DisplayContext } from \"#src/display_context.js\";\nimport { popDragStatus, pushDragStatus } from \"#src/ui/drag_and_drop.js\";\nimport type { Side } from \"#src/ui/side_panel_location.js\";\nimport { TrackableSidePanelLocation } from \"#src/ui/side_panel_location.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { updateChildren } from \"#src/util/dom.js\";\nimport { startRelativeMouseDrag } from \"#src/util/mouse_drag.js\";\nimport { Signal } from \"#src/util/signal.js\";\nimport { WatchableVisibilityPriority } from \"#src/visibility_priority/frontend.js\";\nimport { makeCloseButton } from \"#src/widget/close_button.js\";\n\nexport const DRAG_OVER_CLASSNAME = \"neuroglancer-drag-over\";\n\ntype FlexDirection = \"row\" | \"column\";\n\nconst LOCATION_KEY_FOR_DIRECTION: Record = {\n row: \"row\",\n column: \"col\",\n};\n\nconst OPPOSITE_SIDE: Record = {\n left: \"right\",\n right: \"left\",\n top: \"bottom\",\n bottom: \"top\",\n};\nconst FLEX_DIRECTION_FOR_SIDE: Record = {\n left: \"column\",\n right: \"column\",\n top: \"row\",\n bottom: \"row\",\n};\nconst CROSS_DIRECTION_FOR_SIDE: Record = {\n left: \"row\",\n right: \"row\",\n top: \"column\",\n bottom: \"column\",\n};\nexport const SIZE_FOR_DIRECTION: Record = {\n row: \"width\",\n column: \"height\",\n};\nconst BEGIN_SIDE_FOR_DIRECTION: Record = {\n row: \"left\",\n column: \"top\",\n};\nconst END_SIDE_FOR_DIRECTION: Record = {\n row: \"right\",\n column: \"bottom\",\n};\nconst MARGIN_FOR_SIDE: Record<\n Side,\n \"marginLeft\" | \"marginRight\" | \"marginTop\" | \"marginBottom\"\n> = {\n left: \"marginLeft\",\n right: \"marginRight\",\n top: \"marginTop\",\n bottom: \"marginBottom\",\n};\nconst OUTWARDS_SIGN_FOR_SIDE: Record = {\n left: -1,\n right: +1,\n top: -1,\n bottom: +1,\n};\n\nexport class SidePanel extends RefCounted {\n element: HTMLElement = document.createElement(\"div\");\n visibility = new WatchableVisibilityPriority(\n WatchableVisibilityPriority.VISIBLE,\n );\n constructor(\n public sidePanelManager: SidePanelManager,\n public location: TrackableSidePanelLocation = new TrackableSidePanelLocation(),\n ) {\n super();\n const { element } = this;\n element.classList.add(\"neuroglancer-side-panel\");\n element.draggable = true;\n element.addEventListener(\"dragstart\", (event: DragEvent) => {\n this.sidePanelManager.startDrag(this.makeDragSource(), event);\n element.style.backgroundColor = \"black\";\n setTimeout(() => {\n element.style.backgroundColor = \"\";\n }, 0);\n pushDragStatus(element, \"drag\", () => {\n return document.createTextNode(\n \"Drag side panel to move it to the left/right/top/bottom of another panel\",\n );\n });\n });\n element.addEventListener(\"dragend\", (event: DragEvent) => {\n event;\n this.sidePanelManager.endDrag();\n popDragStatus(element, \"drag\");\n });\n }\n\n makeDragSource(): DragSource {\n return {\n dropAsNewPanel: (location) => {\n const oldLocation = this.location.value;\n this.location.value = { ...oldLocation, ...location };\n this.location.locationChanged.dispatch();\n },\n };\n }\n\n close() {\n this.location.visible = false;\n }\n\n addTitleBar(options: { title?: string }) {\n const titleBar = document.createElement(\"div\");\n titleBar.classList.add(\"neuroglancer-side-panel-titlebar\");\n const { title } = options;\n let titleElement: HTMLElement | undefined;\n if (title !== undefined) {\n titleElement = document.createElement(\"div\");\n titleElement.classList.add(\"neuroglancer-side-panel-title\");\n titleElement.textContent = title;\n titleBar.appendChild(titleElement);\n }\n const closeButton = makeCloseButton({\n title: \"Close panel\",\n onClick: () => {\n this.close();\n },\n });\n closeButton.style.order = \"100\";\n titleBar.appendChild(closeButton);\n this.element.appendChild(titleBar);\n return { titleBar, titleElement, closeButton };\n }\n\n addBody(body: HTMLElement) {\n body.draggable = true;\n body.addEventListener(\"dragstart\", (event: DragEvent) => {\n event.preventDefault();\n event.stopPropagation();\n });\n this.element.appendChild(body);\n }\n}\n\ninterface SidePanelCell {\n registeredPanel: RegisteredSidePanel;\n gutterElement: HTMLElement | undefined;\n}\n\ninterface SidePanelFlex {\n element: HTMLElement;\n visible: boolean;\n crossSize: number;\n // Maximum minWidth over all visible panels in the column.\n minSize: number;\n gutterElement: HTMLElement;\n cells: SidePanelCell[];\n\n beginDropZone: HTMLElement;\n endDropZone: HTMLElement;\n}\n\ninterface SidePanelSideState {\n flexGroups: SidePanelFlex[];\n outerDropZoneElement: HTMLElement;\n}\n\nexport interface SidePanelDropLocation {\n side: Side;\n row: number;\n col: number;\n}\n\nexport interface DragSource {\n canDropAsTabs?: (target: SidePanel) => number;\n dropAsTab?: (target: SidePanel) => void;\n dropAsNewPanel: (location: SidePanelDropLocation) => void;\n}\n\nexport interface RegisteredSidePanel {\n location: TrackableSidePanelLocation;\n makePanel: () => SidePanel;\n panel?: SidePanel | undefined;\n}\n\nexport class SidePanelManager extends RefCounted {\n public element = document.createElement(\"div\");\n public centerColumn = document.createElement(\"div\");\n beforeRender = new Signal();\n private sides: Record = {\n left: this.makeSidePanelSideState(\"left\"),\n right: this.makeSidePanelSideState(\"right\"),\n top: this.makeSidePanelSideState(\"top\"),\n bottom: this.makeSidePanelSideState(\"bottom\"),\n };\n private registeredPanels = new Set();\n dragSource: DragSource | undefined;\n private layoutNeedsUpdate = false;\n\n get visible() {\n return this.visibility.visible;\n }\n constructor(\n public display: DisplayContext,\n public center: HTMLElement,\n public visibility = new WatchableVisibilityPriority(\n WatchableVisibilityPriority.VISIBLE,\n ),\n ) {\n super();\n const { element, centerColumn } = this;\n element.style.display = \"flex\";\n element.style.flex = \"1\";\n element.style.flexDirection = \"row\";\n centerColumn.style.display = \"flex\";\n centerColumn.style.flex = \"1\";\n centerColumn.style.flexDirection = \"column\";\n centerColumn.style.flexBasis = \"0px\";\n centerColumn.style.minWidth = \"0px\";\n this.render();\n this.registerDisposer(\n display.updateStarted.add(() => {\n this.beforeRender.dispatch();\n if (!this.layoutNeedsUpdate) return;\n this.render();\n // Changing the side panel layout can affect the bounds of rendered panels as well.\n ++display.resizeGeneration;\n }),\n );\n this.registerDisposer(this.visibility.changed.add(this.invalidateLayout));\n }\n private makeSidePanelSideState(side: Side): SidePanelSideState {\n return {\n flexGroups: [],\n outerDropZoneElement: this.makeDropZone(\n side,\n /*crossIndex=*/ OUTWARDS_SIGN_FOR_SIDE[side] * Infinity,\n /*flexIndex=*/ 0,\n /*zoneSide=*/ side,\n /*centered=*/ false,\n ),\n };\n }\n\n hasDroppablePanel() {\n return this.dragSource !== undefined;\n }\n\n startDrag(dragSource: DragSource, event: DragEvent) {\n // Use setTimeout to set the attribute that enables the drop zones, rather than setting it\n // synchronously, as otherwise Chrome sometimes fires dragend immediately.\n //\n // https://stackoverflow.com/questions/14203734/dragend-dragenter-and-dragleave-firing-off-immediately-when-i-drag\n setTimeout(() => {\n if (this.dragSource === dragSource) {\n this.element.dataset.neuroglancerSidePanelDrag = \"true\";\n }\n }, 0);\n this.dragSource = dragSource;\n event.stopPropagation();\n event.dataTransfer!.setData(\"neuroglancer-side-panel\", \"\");\n }\n\n endDrag() {\n delete this.element.dataset.neuroglancerSidePanelDrag;\n this.dragSource = undefined;\n }\n\n private makeDropZone(\n side: Side,\n crossIndex: number,\n flexIndex: number,\n zoneSide: Side,\n centered = false,\n ): HTMLElement {\n const element = document.createElement(\"div\");\n element.className = \"neuroglancer-side-panel-drop-zone\";\n const size = 10;\n const zoneFlexDirection = FLEX_DIRECTION_FOR_SIDE[zoneSide];\n const zoneCrossDirection = CROSS_DIRECTION_FOR_SIDE[zoneSide];\n element.style[SIZE_FOR_DIRECTION[zoneCrossDirection]] = `${size}px`;\n element.style[SIZE_FOR_DIRECTION[zoneFlexDirection]] = \"100%\";\n if (centered) {\n element.style.position = \"absolute\";\n element.style[zoneSide] = \"50%\";\n element.style[MARGIN_FOR_SIDE[zoneSide]] = \"-${size/2}px\";\n } else {\n element.style.position = \"relative\";\n element.style[MARGIN_FOR_SIDE[OPPOSITE_SIDE[zoneSide]]] = `-${size}px`;\n }\n element.addEventListener(\"dragenter\", (event) => {\n if (!this.hasDroppablePanel()) return;\n element.classList.add(DRAG_OVER_CLASSNAME);\n event.preventDefault();\n pushDragStatus(element, \"drop\", () =>\n document.createTextNode(`Drop side panel as new ${zoneFlexDirection}`),\n );\n });\n element.addEventListener(\"dragleave\", () => {\n popDragStatus(element, \"drop\");\n element.classList.remove(DRAG_OVER_CLASSNAME);\n });\n element.addEventListener(\"dragover\", (event) => {\n if (!this.hasDroppablePanel()) return;\n event.preventDefault();\n });\n element.addEventListener(\"drop\", (event) => {\n const { dragSource } = this;\n if (dragSource === undefined) return;\n popDragStatus(element, \"drop\");\n element.classList.remove(DRAG_OVER_CLASSNAME);\n const flexDirection = FLEX_DIRECTION_FOR_SIDE[side];\n dragSource.dropAsNewPanel({\n side,\n row: flexDirection === \"column\" ? flexIndex : crossIndex,\n col: flexDirection === \"row\" ? flexIndex : crossIndex,\n });\n this.dragSource = undefined;\n event.preventDefault();\n event.stopPropagation();\n });\n return element;\n }\n\n registerPanel(registeredPanel: RegisteredSidePanel) {\n this.registeredPanels.add(registeredPanel);\n this.invalidateLayout();\n registeredPanel.location.locationChanged.add(this.invalidateLayout);\n return () => {\n this.unregisterPanel(registeredPanel);\n };\n }\n\n unregisterPanel(registeredPanel: RegisteredSidePanel) {\n this.registeredPanels.delete(registeredPanel);\n registeredPanel.location.locationChanged.remove(this.invalidateLayout);\n registeredPanel.panel?.dispose();\n this.invalidateLayout();\n }\n\n disposed() {\n for (const { panel } of this.registeredPanels) {\n panel?.dispose();\n }\n super.disposed();\n }\n\n invalidateLayout = () => {\n this.layoutNeedsUpdate = true;\n this.display.scheduleRedraw();\n };\n\n render() {\n this.layoutNeedsUpdate = false;\n const sides: Record = {\n left: [],\n right: [],\n top: [],\n bottom: [],\n };\n for (const panel of this.registeredPanels) {\n sides[panel.location.value.side].push(panel);\n }\n const getSideChildren = (side: Side) =>\n this.renderSide(side, this.sides[side].flexGroups, sides[side]);\n const self = this;\n function* getRowChildren() {\n yield self.sides.left.outerDropZoneElement;\n yield* getSideChildren(\"left\");\n yield self.centerColumn;\n yield* getSideChildren(\"right\");\n yield self.sides.right.outerDropZoneElement;\n }\n updateChildren(this.element, getRowChildren());\n function* getColumnChildren() {\n yield self.sides.top.outerDropZoneElement;\n yield* getSideChildren(\"top\");\n yield self.center;\n yield* getSideChildren(\"bottom\");\n yield self.sides.bottom.outerDropZoneElement;\n }\n updateChildren(this.centerColumn, getColumnChildren());\n }\n\n private makeCrossGutter(side: Side, crossIndex: number) {\n const gutter = document.createElement(\"div\");\n gutter.style.position = \"relative\";\n const direction = CROSS_DIRECTION_FOR_SIDE[side];\n gutter.className = `neuroglancer-resize-gutter-${\n direction === \"row\" ? \"horizontal\" : \"vertical\"\n }`;\n gutter.addEventListener(\"pointerdown\", (event) => {\n if (\"button\" in event && event.button !== 0) {\n return;\n }\n event.preventDefault();\n const flexGroup = this.sides[side].flexGroups[crossIndex];\n if (flexGroup === undefined || !flexGroup.visible) return;\n // Get initial size\n const initialRect = flexGroup.element.getBoundingClientRect();\n let size = initialRect[SIZE_FOR_DIRECTION[direction]];\n const minSize = flexGroup.minSize;\n const updateMessage = () => {\n pushDragStatus(\n gutter,\n \"drag\",\n `Drag to resize, current ${SIZE_FOR_DIRECTION[direction]} is ${flexGroup.crossSize}px`,\n );\n };\n updateMessage();\n startRelativeMouseDrag(\n event,\n (_event, deltaX: number, deltaY: number) => {\n const delta = direction === \"row\" ? deltaX : deltaY;\n size -= OUTWARDS_SIGN_FOR_SIDE[side] * delta;\n flexGroup.crossSize = Math.max(minSize, Math.round(size));\n updateMessage();\n this.invalidateLayout();\n },\n () => {\n popDragStatus(gutter, \"drag\");\n },\n );\n });\n const dropZone = this.makeDropZone(\n side,\n crossIndex - OUTWARDS_SIGN_FOR_SIDE[side] * 0.5,\n /*flexIndex=*/ 0,\n /*zoneSide=*/ side,\n /*centered=*/ true,\n );\n gutter.appendChild(dropZone);\n return gutter;\n }\n\n private makeFlexGutter(side: Side, crossIndex: number, flexIndex: number) {\n const gutter = document.createElement(\"div\");\n gutter.style.position = \"relative\";\n const direction = FLEX_DIRECTION_FOR_SIDE[side];\n gutter.className = `neuroglancer-resize-gutter-${\n direction === \"row\" ? \"horizontal\" : \"vertical\"\n }`;\n gutter.addEventListener(\"pointerdown\", (event) => {\n if (\"button\" in event && event.button !== 0) {\n return;\n }\n event.preventDefault();\n const flexGroup = this.sides[side].flexGroups[crossIndex];\n if (flexGroup === undefined || !flexGroup.visible) return;\n const { cells } = flexGroup;\n const cell = cells[flexIndex];\n if (cell === undefined || !cell.registeredPanel.location.visible) return;\n // Determine the cell index of the next visible panel.\n let nextFlexIndex = flexIndex + 1;\n while (\n nextFlexIndex < cells.length &&\n !cells[nextFlexIndex].registeredPanel.location.visible\n ) {\n ++nextFlexIndex;\n }\n if (nextFlexIndex === cells.length) return;\n const nextCell = cells[nextFlexIndex];\n const updateMessage = () => {\n pushDragStatus(\n gutter,\n \"drag\",\n `Drag to resize, current ${SIZE_FOR_DIRECTION[direction]} ratio is ` +\n `${cell.registeredPanel.location.value.flex} : ` +\n `${nextCell.registeredPanel.location.value.flex}`,\n );\n };\n updateMessage();\n startRelativeMouseDrag(\n event,\n (newEvent) => {\n const firstPanel = cell.registeredPanel.panel;\n const secondPanel = nextCell.registeredPanel.panel;\n if (firstPanel === undefined || secondPanel === undefined) return;\n const firstRect = firstPanel.element.getBoundingClientRect();\n const secondRect = secondPanel.element.getBoundingClientRect();\n const firstFraction = Math.max(\n 0.1,\n Math.min(\n 0.9,\n direction === \"column\"\n ? (newEvent.clientY - firstRect.top) /\n (secondRect.bottom - firstRect.top)\n : (newEvent.clientX - firstRect.left) /\n (secondRect.right - firstRect.left),\n ),\n );\n const firstLocation = cell.registeredPanel.location.value;\n const secondLocation = nextCell.registeredPanel.location.value;\n const existingFlexSum = firstLocation.flex + secondLocation.flex;\n cell.registeredPanel.location.value = {\n ...firstLocation,\n flex: Math.round(firstFraction * existingFlexSum * 100) / 100,\n };\n nextCell.registeredPanel.location.value = {\n ...secondLocation,\n flex: Math.round((1 - firstFraction) * existingFlexSum * 100) / 100,\n };\n updateMessage();\n cell.registeredPanel.location.locationChanged.dispatch();\n nextCell.registeredPanel.location.locationChanged.dispatch();\n this.invalidateLayout();\n },\n () => {\n popDragStatus(gutter, \"drag\");\n },\n );\n });\n const dropZone = this.makeDropZone(\n side,\n crossIndex,\n /*flexIndex=*/ flexIndex + 0.5,\n /*zoneSide=*/ BEGIN_SIDE_FOR_DIRECTION[FLEX_DIRECTION_FOR_SIDE[side]],\n /*centered=*/ true,\n );\n gutter.appendChild(dropZone);\n return gutter;\n }\n\n private renderSide(\n side: Side,\n flexGroups: SidePanelFlex[],\n panels: RegisteredSidePanel[],\n ) {\n const flexKey = LOCATION_KEY_FOR_DIRECTION[CROSS_DIRECTION_FOR_SIDE[side]];\n const crossKey = LOCATION_KEY_FOR_DIRECTION[FLEX_DIRECTION_FOR_SIDE[side]];\n panels.sort((a, b) => {\n const aLoc = a.location.value;\n const bLoc = b.location.value;\n const crossDiff = aLoc[crossKey] - bLoc[crossKey];\n if (crossDiff !== 0) return crossDiff;\n return aLoc[flexKey] - bLoc[flexKey];\n });\n const self = this;\n function* getFlexGroups() {\n let panelIndex = 0;\n const numPanels = panels.length;\n let crossIndex = 0;\n while (panelIndex < numPanels) {\n const origCrossIndex = panels[panelIndex].location.value[crossKey];\n let endPanelIndex = panelIndex;\n let numVisible = 0;\n let minSize = 0;\n do {\n const location = panels[endPanelIndex].location.value;\n if (location[crossKey] !== origCrossIndex) break;\n if (location.visible) {\n ++numVisible;\n minSize = Math.max(minSize, location.minSize);\n }\n ++endPanelIndex;\n } while (endPanelIndex < numPanels);\n const visible = numVisible > 0;\n let flexGroup = flexGroups[crossIndex];\n if (flexGroup === undefined) {\n const gutter = self.makeCrossGutter(side, crossIndex);\n const flexGroupElement = document.createElement(\"div\");\n flexGroupElement.className = `neuroglancer-side-panel-${FLEX_DIRECTION_FOR_SIDE[side]}`;\n flexGroup = flexGroups[crossIndex] = {\n element: flexGroupElement,\n gutterElement: gutter,\n cells: [],\n crossSize: -1,\n minSize,\n visible,\n beginDropZone: self.makeDropZone(\n side,\n crossIndex,\n /*flexIndex=*/ -Infinity,\n BEGIN_SIDE_FOR_DIRECTION[FLEX_DIRECTION_FOR_SIDE[side]],\n ),\n endDropZone: self.makeDropZone(\n side,\n crossIndex,\n /*flexIndex=*/ +Infinity,\n END_SIDE_FOR_DIRECTION[FLEX_DIRECTION_FOR_SIDE[side]],\n ),\n };\n } else {\n flexGroup.visible = visible;\n flexGroup.minSize = minSize;\n flexGroup.crossSize = Math.max(flexGroup.crossSize, minSize);\n }\n function* getCells() {\n yield flexGroup.beginDropZone;\n let prevVisible = 0;\n for (\n let i = panelIndex, flexIndex = 0;\n i < endPanelIndex;\n ++i, ++flexIndex\n ) {\n const registeredPanel = panels[i];\n let cell = flexGroup.cells[flexIndex];\n if (cell === undefined) {\n cell = flexGroup.cells[flexIndex] = {\n registeredPanel,\n gutterElement: undefined,\n };\n } else {\n cell.registeredPanel = registeredPanel;\n }\n const oldLocation = cell.registeredPanel.location.value;\n if (flexGroup.crossSize === -1) {\n flexGroup.crossSize = Math.max(minSize, oldLocation.size);\n }\n if (\n oldLocation[crossKey] !== crossIndex ||\n oldLocation[flexKey] !== flexIndex ||\n (oldLocation.visible && oldLocation.size !== flexGroup.crossSize)\n ) {\n cell.registeredPanel.location.value = {\n ...oldLocation,\n [crossKey]: crossIndex,\n [flexKey]: flexIndex,\n size: oldLocation.visible\n ? flexGroup.crossSize\n : oldLocation.size,\n };\n cell.registeredPanel.location.changed.dispatch();\n }\n const visible = oldLocation.visible && self.visibility.visible;\n let { panel } = registeredPanel;\n if (!visible) {\n if (panel !== undefined) {\n panel.dispose();\n registeredPanel.panel = undefined;\n }\n continue;\n }\n ++prevVisible;\n if (panel === undefined) {\n panel = registeredPanel.panel = registeredPanel.makePanel();\n }\n panel.element.style.flex =\n numVisible > 1 ? `${oldLocation.flex}` : \"1\";\n yield panel.element;\n if (prevVisible === numVisible) {\n // Last cell does not need its own resize gutter.\n cell.gutterElement = undefined;\n } else {\n if (cell.gutterElement === undefined) {\n cell.gutterElement = self.makeFlexGutter(\n side,\n crossIndex,\n flexIndex,\n );\n }\n yield cell.gutterElement;\n }\n }\n yield flexGroup.endDropZone;\n }\n updateChildren(flexGroup.element, getCells());\n flexGroup.cells.length = endPanelIndex - panelIndex;\n if (visible) {\n flexGroup.element.style[\n SIZE_FOR_DIRECTION[CROSS_DIRECTION_FOR_SIDE[side]]\n ] = `${flexGroup.crossSize}px`;\n if (OUTWARDS_SIGN_FOR_SIDE[side] > 0) {\n yield flexGroup.gutterElement;\n yield flexGroup.element;\n } else {\n yield flexGroup.element;\n yield flexGroup.gutterElement;\n }\n }\n panelIndex = endPanelIndex;\n ++crossIndex;\n }\n flexGroups.length = crossIndex;\n }\n return getFlexGroups();\n }\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { MakeIconOptions } from \"#src/widget/icon.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\n\nexport function makeMoveToButton(options: MakeIconOptions = {}) {\n return makeIcon({ text: \"↗\", ...options });\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/ui/selection_details.css\";\n\nimport svg_arrowLeft from \"ikonate/icons/arrow-left.svg?raw\";\nimport svg_arrowRight from \"ikonate/icons/arrow-right.svg?raw\";\nimport type {\n SelectedLayerState,\n TopLevelLayerListSpecification,\n TrackableDataSelectionState,\n} from \"#src/layer/index.js\";\nimport { getDefaultSelectBindings } from \"#src/ui/default_input_event_bindings.js\";\nimport type { SidePanelManager } from \"#src/ui/side_panel.js\";\nimport { SidePanel } from \"#src/ui/side_panel.js\";\nimport { setClipboard } from \"#src/util/clipboard.js\";\nimport type { Borrowed } from \"#src/util/disposable.js\";\nimport { MouseEventBinder } from \"#src/util/mouse_bindings.js\";\nimport { CheckboxIcon } from \"#src/widget/checkbox_icon.js\";\nimport { makeCopyButton } from \"#src/widget/copy_button.js\";\nimport { DependentViewWidget } from \"#src/widget/dependent_view_widget.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\nimport { makeMoveToButton } from \"#src/widget/move_to_button.js\";\n\nexport function isWithinSelectionPanel(element: HTMLElement) {\n return element.closest(\".neuroglancer-selection-details\");\n}\n\nexport class SelectionDetailsPanel extends SidePanel {\n body = document.createElement(\"div\");\n\n constructor(\n public sidePanelManager: SidePanelManager,\n public state: Borrowed,\n public manager: Borrowed,\n public selectedLayer: Borrowed,\n ) {\n super(sidePanelManager, state.location);\n const { element, body } = this;\n element.classList.add(\"neuroglancer-selection-details\");\n this.registerDisposer(\n new MouseEventBinder(this.element, getDefaultSelectBindings()),\n );\n\n const { titleBar } = this.addTitleBar({ title: \"Selection\" });\n const backButton = makeIcon({\n svg: svg_arrowLeft,\n title: \"Previous selection\",\n onClick: () => {\n this.state.goBack();\n },\n });\n const forwardButton = makeIcon({\n svg: svg_arrowRight,\n title: \"Next selection\",\n onClick: () => {\n this.state.goForward();\n },\n });\n titleBar.appendChild(backButton);\n titleBar.appendChild(forwardButton);\n titleBar.appendChild(\n this.registerDisposer(\n new CheckboxIcon(state.pin, {\n // Note: \\ufe0e forces text display, as otherwise the pin icon may as an emoji with\n // color.\n text: \"📌\\ufe0e\",\n enableTitle: \"Pin selection\",\n disableTitle: \"Unpin selection\",\n }),\n ).element,\n );\n body.classList.add(\"neuroglancer-selection-details-body\");\n this.addBody(body);\n body.appendChild(\n this.registerDisposer(\n new DependentViewWidget(state, (stateValue, parent, context) => {\n if (!state.location.visible) return;\n backButton.style.visibility = state.canGoBack()\n ? \"visible\"\n : \"hidden\";\n forwardButton.style.visibility = state.canGoForward()\n ? \"visible\"\n : \"hidden\";\n if (stateValue === undefined) return;\n\n // Add position\n const { position } = stateValue;\n if (position !== undefined) {\n const positionElement = document.createElement(\"div\");\n positionElement.classList.add(\n \"neuroglancer-selection-details-position\",\n );\n const copyButton = makeCopyButton({\n title: \"Copy position\",\n onClick: () => {\n setClipboard(position!.map((x) => Math.floor(x)).join(\", \"));\n },\n });\n positionElement.appendChild(copyButton);\n const {\n coordinateSpace: { rank, names },\n position,\n } = stateValue;\n for (let i = 0; i < rank; ++i) {\n const dimElement = document.createElement(\"span\");\n dimElement.classList.add(\n \"neuroglancer-selection-details-position-dimension\",\n );\n const nameElement = document.createElement(\"span\");\n nameElement.classList.add(\n \"neuroglancer-selection-details-position-dimension-name\",\n );\n nameElement.textContent = names[i];\n const coordinateElement = document.createElement(\"span\");\n coordinateElement.classList.add(\n \"neuroglancer-selection-details-position-dimension-coordinate\",\n );\n coordinateElement.textContent = Math.floor(\n position![i],\n ).toString();\n dimElement.appendChild(nameElement);\n dimElement.appendChild(coordinateElement);\n positionElement.appendChild(dimElement);\n }\n const moveToButton = makeMoveToButton({\n title: \"Move to position\",\n onClick: () => {\n this.manager.globalPosition.value = position!;\n },\n });\n positionElement.appendChild(moveToButton);\n parent.appendChild(positionElement);\n }\n\n for (const layerData of stateValue.layers) {\n const { layer } = layerData;\n parent.appendChild(\n context.registerDisposer(\n new DependentViewWidget(\n {\n value: undefined,\n changed: layer.managedLayer.layerChanged,\n },\n (_, parent, context) => {\n if (layer.wasDisposed) return;\n if (!layer.isReady) {\n return;\n }\n const layerBody = document.createElement(\"div\");\n layerBody.classList.add(\n \"neuroglancer-selection-details-layer-body\",\n );\n if (\n !layer.displaySelectionState(\n layerData.state,\n layerBody,\n context,\n )\n ) {\n return;\n }\n const layerElement = document.createElement(\"div\");\n parent.appendChild(layerElement);\n layerElement.classList.add(\n \"neuroglancer-selection-details-layer\",\n );\n const layerTitle = document.createElement(\"div\");\n layerTitle.classList.add(\n \"neuroglancer-selection-details-layer-title\",\n );\n layerTitle.textContent = layer.managedLayer.name;\n layerTitle.addEventListener(\"click\", () => {\n this.selectedLayer.layer = layer.managedLayer;\n this.selectedLayer.visible = true;\n });\n layerTitle.title = \"Click to show layer side panel\";\n layerElement.appendChild(layerTitle);\n layerElement.appendChild(layerBody);\n },\n ),\n ).element,\n );\n }\n }),\n ).element,\n );\n }\n\n close() {\n super.close();\n this.state.value = undefined;\n this.state.pin.value = true;\n }\n}\n","/**\n * @license\n * Copyright 2023 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/eye_button.css\";\n\nimport svg_eye_crossed from \"ikonate/icons/eye-crossed.svg?raw\";\nimport type { MakeIconOptions } from \"#src/widget/icon.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\n\nexport function makeEyeButton(options: MakeIconOptions = {}) {\n const icon = makeIcon({ svg: svg_eye_crossed, ...options });\n icon.classList.add(\"neuroglancer-eye-icon\");\n return icon;\n}\n","/**\n * @license\n * Copyright 2020 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport svg_filter from \"ikonate/icons/filter.svg?raw\";\nimport type { MakeIconOptions } from \"#src/widget/icon.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\n\nexport function makeFilterButton(options: MakeIconOptions = {}) {\n return makeIcon({ svg: svg_filter, ...options });\n}\n","/**\n * @license\n * Copyright 2019 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport \"#src/widget/star_button.css\";\n\nimport svg_star from \"ikonate/icons/star.svg?raw\";\nimport type { MakeIconOptions } from \"#src/widget/icon.js\";\nimport { makeIcon } from \"#src/widget/icon.js\";\n\nexport function makeStarButton(options: MakeIconOptions = {}) {\n const icon = makeIcon({ svg: svg_star, ...options });\n icon.classList.add(\"neuroglancer-star-icon\");\n return icon;\n}\n","/**\n * @license\n * Copyright 2016 Google Inc.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { LayerChunkProgressInfo } from \"#src/chunk_manager/base.js\";\nimport type { ChunkManager } from \"#src/chunk_manager/frontend.js\";\nimport { ChunkRenderLayerFrontend } from \"#src/chunk_manager/frontend.js\";\nimport type { LayerSelectedValues } from \"#src/layer/index.js\";\nimport type { SegmentationUserLayer } from \"#src/layer/segmentation/index.js\";\nimport type { PickIDManager } from \"#src/object_picking.js\";\nimport type { WatchableRenderLayerTransform } from \"#src/render_coordinate_transform.js\";\nimport type { RenderScaleHistogram } from \"#src/render_scale_statistics.js\";\nimport type { RenderLayer } from \"#src/renderlayer.js\";\nimport type { SegmentColorHash } from \"#src/segment_color.js\";\nimport { getCssColor } from \"#src/segment_color.js\";\nimport type { VisibleSegmentsState } from \"#src/segmentation_display_state/base.js\";\nimport {\n forEachVisibleSegment,\n onTemporaryVisibleSegmentsStateChanged,\n onVisibleSegmentsStateChanged,\n VISIBLE_SEGMENTS_STATE_PROPERTIES,\n} from \"#src/segmentation_display_state/base.js\";\nimport type {\n InlineSegmentNumericalProperty,\n InlineSegmentProperty,\n PreprocessedSegmentPropertyMap,\n} from \"#src/segmentation_display_state/property_map.js\";\nimport { SharedWatchableValue } from \"#src/shared_watchable_value.js\";\nimport type { TrackableAlphaValue } from \"#src/trackable_alpha.js\";\nimport type {\n TrackableValue,\n WatchableValueInterface,\n} from \"#src/trackable_value.js\";\nimport { observeWatchable, registerNestedSync } from \"#src/trackable_value.js\";\nimport { isWithinSelectionPanel } from \"#src/ui/selection_details.js\";\nimport type { Uint64Map } from \"#src/uint64_map.js\";\nimport { setClipboard } from \"#src/util/clipboard.js\";\nimport {\n packColor,\n serializeColor,\n TrackableRGB,\n useWhiteBackground,\n} from \"#src/util/color.js\";\nimport { RefCounted } from \"#src/util/disposable.js\";\nimport { measureElementClone } from \"#src/util/dom.js\";\nimport { kOneVec, vec3, vec4 } from \"#src/util/geom.js\";\nimport { NullarySignal } from \"#src/util/signal.js\";\nimport { Uint64 } from \"#src/util/uint64.js\";\nimport { withSharedVisibility } from \"#src/visibility_priority/frontend.js\";\nimport { ColorWidget } from \"#src/widget/color.js\";\nimport { makeCopyButton } from \"#src/widget/copy_button.js\";\nimport { makeEyeButton } from \"#src/widget/eye_button.js\";\nimport { makeFilterButton } from \"#src/widget/filter_button.js\";\nimport { makeStarButton } from \"#src/widget/star_button.js\";\n\nexport class Uint64MapEntry {\n constructor(\n public key: Uint64,\n public value?: Uint64,\n public label?: string | undefined,\n ) {}\n toString() {\n const { key, value, label } = this;\n let baseString: string;\n if (value === undefined) {\n baseString = `${key}`;\n } else {\n baseString = `${key}→${value}`;\n }\n if (label === undefined) return baseString;\n return `${baseString} ${label}`;\n }\n}\n\nexport class SegmentSelectionState extends RefCounted {\n selectedSegment = new Uint64();\n baseSelectedSegment = new Uint64();\n hasSelectedSegment = false;\n changed = new NullarySignal();\n\n get value() {\n return this.hasSelectedSegment ? this.selectedSegment : undefined;\n }\n\n get baseValue() {\n return this.hasSelectedSegment ? this.baseSelectedSegment : undefined;\n }\n\n set(\n value: number | Uint64MapEntry | Uint64 | null | undefined,\n hideSegmentZero = false,\n ) {\n const { selectedSegment, baseSelectedSegment } = this;\n let newLow = 0;\n let newHigh = 0;\n let newBaseLow = 0;\n let newBaseHigh = 0;\n let hasSelectedSegment: boolean;\n if (value == null) {\n hasSelectedSegment = false;\n } else if (typeof value === \"number\") {\n newLow = newBaseLow = value >>> 0;\n newHigh = newBaseHigh = value < 0 ? 0xffffffff : 0;\n hasSelectedSegment = true;\n } else if (value instanceof Uint64MapEntry) {\n const valueMapped = value.value || value.key;\n newLow = valueMapped.low;\n newHigh = valueMapped.high;\n newBaseLow = value.key.low;\n newBaseHigh = value.key.high;\n hasSelectedSegment = true;\n } else if (value instanceof Uint64) {\n newLow = newBaseLow = value.low;\n newHigh = newBaseHigh = value.high;\n hasSelectedSegment = true;\n } else {\n hasSelectedSegment = false;\n }\n if (hideSegmentZero && newLow === 0 && newHigh === 0) {\n hasSelectedSegment = false;\n }\n if (!hasSelectedSegment) {\n if (this.hasSelectedSegment) {\n this.hasSelectedSegment = false;\n this.changed.dispatch();\n }\n } else if (\n hasSelectedSegment &&\n (!this.hasSelectedSegment ||\n selectedSegment.low !== newLow ||\n selectedSegment.high !== newHigh ||\n baseSelectedSegment.low !== newBaseLow ||\n baseSelectedSegment.high !== newBaseHigh)\n ) {\n selectedSegment.low = newLow;\n selectedSegment.high = newHigh;\n baseSelectedSegment.low = newBaseLow;\n baseSelectedSegment.high = newBaseHigh;\n this.hasSelectedSegment = true;\n this.changed.dispatch();\n }\n }\n\n isSelected(value: Uint64) {\n return this.hasSelectedSegment && Uint64.equal(value, this.selectedSegment);\n }\n\n bindTo(\n layerSelectedValues: LayerSelectedValues,\n userLayer: SegmentationUserLayer,\n ) {\n this.registerDisposer(\n layerSelectedValues.changed.add(() => {\n const state = layerSelectedValues.get(userLayer);\n let value: any = undefined;\n if (state !== undefined) {\n value = state.value;\n }\n this.set(\n value,\n userLayer.displayState.segmentationGroupState.value.hideSegmentZero\n .value,\n );\n }),\n );\n }\n}\n\nexport interface SegmentationGroupState extends VisibleSegmentsState {\n /**\n * Maximum length of base-10 representation of id seen.\n */\n maxIdLength: WatchableValueInterface;\n segmentPropertyMap: WatchableValueInterface<\n PreprocessedSegmentPropertyMap | undefined\n >;\n}\n\nexport interface SegmentationColorGroupState {\n segmentColorHash: SegmentColorHash;\n segmentStatedColors: Uint64Map;\n tempSegmentStatedColors2d: Uint64Map;\n segmentDefaultColor: WatchableValueInterface;\n tempSegmentDefaultColor2d: WatchableValueInterface;\n}\n\nexport interface SegmentationDisplayState {\n segmentSelectionState: SegmentSelectionState;\n saturation: TrackableAlphaValue;\n hoverHighlight: WatchableValueInterface;\n baseSegmentColoring: WatchableValueInterface;\n baseSegmentHighlighting: WatchableValueInterface;\n segmentationGroupState: WatchableValueInterface;\n segmentationColorGroupState: WatchableValueInterface;\n\n selectSegment: (id: Uint64, pin: boolean | \"toggle\") => void;\n filterBySegmentLabel: (id: Uint64) => void;\n moveToSegment: (id: Uint64) => void;\n\n // Indirect properties\n hideSegmentZero: WatchableValueInterface;\n segmentColorHash: WatchableValueInterface;\n segmentStatedColors: WatchableValueInterface;\n tempSegmentStatedColors2d: WatchableValueInterface;\n useTempSegmentStatedColors2d: WatchableValueInterface;\n segmentDefaultColor: WatchableValueInterface;\n tempSegmentDefaultColor2d: WatchableValueInterface;\n highlightColor: WatchableValueInterface;\n}\n\nexport function resetTemporaryVisibleSegmentsState(\n state: VisibleSegmentsState,\n) {\n state.useTemporarySegmentEquivalences.value = false;\n state.useTemporaryVisibleSegments.value = false;\n state.temporaryVisibleSegments.clear();\n state.temporarySegmentEquivalences.clear();\n}\n\n/// Converts a segment id to a Uint64MapEntry or Uint64 (if Uint64MapEntry would add no additional\n/// information).\nexport function maybeAugmentSegmentId(\n displayState: SegmentationDisplayState | undefined | null,\n value: number | Uint64,\n mustCopy = false,\n): Uint64 | Uint64MapEntry {\n let id: Uint64;\n let mappedValue: Uint64;\n let mapped: Uint64 | undefined;\n if (typeof value === \"number\") {\n id = new Uint64(value >>> 0, value < 0 ? 0xffffffff : 0);\n } else if (typeof value === \"string\") {\n id = Uint64.parseString(value);\n } else {\n id = mustCopy ? value.clone() : value;\n }\n if (displayState == null) return id;\n const {\n segmentEquivalences,\n segmentPropertyMap: { value: segmentPropertyMap },\n } = displayState.segmentationGroupState.value;\n if (segmentEquivalences.size !== 0) {\n mappedValue = segmentEquivalences.get(id);\n if (Uint64.equal(mappedValue, id)) {\n mapped = undefined;\n } else {\n mapped = mappedValue;\n }\n } else {\n mappedValue = id;\n }\n const label = segmentPropertyMap?.getSegmentLabel(mappedValue);\n if (label === undefined && mapped === undefined) {\n return id;\n }\n return new Uint64MapEntry(id, mapped, label);\n}\n\n/// Converts a plain segment id to a Uint64MapEntry.\nexport function augmentSegmentId(\n displayState: SegmentationDisplayState | undefined | null,\n value: number | Uint64 | Uint64MapEntry,\n): Uint64MapEntry {\n if (value instanceof Uint64MapEntry) return value;\n const newValue = maybeAugmentSegmentId(displayState, value);\n if (newValue instanceof Uint64) {\n return new Uint64MapEntry(newValue);\n }\n return newValue;\n}\n\nexport function updateIdStringWidth(\n idStringWidth: WatchableValueInterface,\n idString: string,\n) {\n const { length } = idString;\n if (idStringWidth.value < length) {\n idStringWidth.value = length;\n }\n}\n\nexport function bindSegmentListWidth(\n displayState: SegmentationDisplayState,\n element: HTMLElement,\n) {\n return observeWatchable(\n (width) =>\n element.style.setProperty(\n \"--neuroglancer-segment-list-width\",\n `${width}ch`,\n ),\n displayState.segmentationGroupState.value.maxIdLength,\n );\n}\n\nconst segmentWidgetTemplate = (() => {\n const template = document.createElement(\"div\");\n template.classList.add(\"neuroglancer-segment-list-entry\");\n const stickyContainer = document.createElement(\"div\");\n stickyContainer.classList.add(\"neuroglancer-segment-list-entry-sticky\");\n template.appendChild(stickyContainer);\n const copyButton = makeCopyButton({\n title: \"Copy segment ID\",\n });\n copyButton.classList.add(\"neuroglancer-segment-list-entry-copy\");\n const copyContainer = document.createElement(\"div\");\n copyContainer.classList.add(\"neuroglancer-segment-list-entry-copy-container\");\n const copyIndex = copyContainer.childElementCount;\n copyContainer.appendChild(copyButton);\n const copyContainerIndex = stickyContainer.childElementCount;\n stickyContainer.appendChild(copyContainer);\n const visibleIndex = stickyContainer.childElementCount;\n const visibleIcon = makeEyeButton({\n title: \"Toggle segment visibility\",\n });\n visibleIcon.classList.add(\"neuroglancer-segment-list-entry-visible-checkbox\");\n stickyContainer.appendChild(visibleIcon);\n const idContainer = document.createElement(\"div\");\n idContainer.classList.add(\"neuroglancer-segment-list-entry-id-container\");\n const idContainerIndex = stickyContainer.childElementCount;\n stickyContainer.appendChild(idContainer);\n const idElement = document.createElement(\"div\");\n idElement.classList.add(\"neuroglancer-segment-list-entry-id\");\n const idIndex = idContainer.childElementCount;\n idContainer.appendChild(idElement);\n const starButton = makeStarButton({\n title: \"Star segment\",\n });\n starButton.classList.add(\"neuroglancer-segment-list-entry-star\");\n const starIndex = stickyContainer.childElementCount;\n stickyContainer.appendChild(starButton);\n\n const nameElement = document.createElement(\"span\");\n nameElement.classList.add(\"neuroglancer-segment-list-entry-name\");\n const labelIndex = template.childElementCount;\n template.appendChild(nameElement);\n const filterElement = makeFilterButton({\n title: \"Filter by label\",\n });\n filterElement.classList.add(\"neuroglancer-segment-list-entry-filter\");\n const filterIndex = template.childElementCount;\n template.appendChild(filterElement);\n const colorWidgetIndex = template.childElementCount;\n template.appendChild(ColorWidget.template());\n return {\n template,\n copyContainerIndex,\n copyIndex,\n visibleIndex,\n idContainerIndex,\n idIndex,\n labelIndex,\n filterIndex,\n starIndex,\n colorWidgetIndex,\n unmappedIdIndex: -1,\n unmappedCopyIndex: -1,\n };\n})();\n\nconst segmentWidgetTemplateWithUnmapped = (() => {\n const t = segmentWidgetTemplate;\n const template = t.template.cloneNode(/*deep=*/ true) as HTMLDivElement;\n const stickyContainer = template.children[0] as HTMLElement;\n const idContainer = stickyContainer.children[\n t.idContainerIndex\n ] as HTMLElement;\n const unmappedIdIndex = idContainer.childElementCount;\n const unmappedIdElement = idContainer.children[t.idIndex].cloneNode(\n /*deep=*/ true,\n ) as HTMLElement;\n unmappedIdElement.classList.add(\n \"neuroglancer-segment-list-entry-unmapped-id\",\n );\n idContainer.appendChild(unmappedIdElement);\n const copyContainer = stickyContainer.children[\n t.copyContainerIndex\n ] as HTMLElement;\n const unmappedCopyIndex = copyContainer.childElementCount;\n copyContainer.appendChild(\n copyContainer.children[t.copyIndex].cloneNode(/*deep=*/ true),\n );\n return { ...t, template, unmappedIdIndex, unmappedCopyIndex };\n})();\n\nexport type SegmentWidgetTemplate = typeof segmentWidgetTemplate;\n\ninterface SegmentWidgetWithExtraColumnsTemplate extends SegmentWidgetTemplate {\n numericalPropertyIndices: number[];\n}\n\nexport function segmentWidgetTemplateWithExtraColumns(\n numExtraColumns: number,\n): SegmentWidgetWithExtraColumnsTemplate {\n const origTemplate = segmentWidgetTemplate;\n const templateElement = origTemplate.template.cloneNode(\n /*deep=*/ true,\n ) as HTMLDivElement;\n const numericalPropertyIndices: number[] = [];\n for (let i = 0; i < numExtraColumns; ++i) {\n numericalPropertyIndices.push(templateElement.childElementCount);\n const child = document.createElement(\"div\");\n child.classList.add(\"neuroglancer-segment-list-entry-extra-property\");\n child.style.width = `max(var(--neuroglancer-column-${i}-width), var(--neuroglancer-column-${i}-label-width))`;\n templateElement.appendChild(child);\n }\n return {\n ...origTemplate,\n template: templateElement,\n numericalPropertyIndices,\n };\n}\n\nconst cachedRegisterSegmentWidgetEventHandlers = new WeakMap<\n SegmentationDisplayState,\n (element: HTMLElement, template: SegmentWidgetTemplate) => void\n>();\n\nfunction makeRegisterSegmentWidgetEventHandlers(\n displayState: SegmentationDisplayState,\n) {\n const onMouseEnter = (event: Event) => {\n const entryElement = event.currentTarget as HTMLElement;\n const idString = entryElement.dataset.id!;\n const id = tempObjectId;\n id.tryParseString(idString);\n displayState.segmentSelectionState.set(id);\n if (!isWithinSelectionPanel(entryElement)) {\n displayState.selectSegment(id, false);\n }\n };\n\n const selectHandler = (event: Event) => {\n const entryElement = event.currentTarget as HTMLElement;\n const idString = entryElement.dataset.id!;\n const id = tempObjectId;\n id.tryParseString(idString);\n displayState.selectSegment(\n id,\n isWithinSelectionPanel(entryElement) ? \"toggle\" : true,\n );\n };\n\n const onMouseLeave = () => {\n displayState.segmentSelectionState.set(null);\n };\n\n const getEntryElement = (event: Event): HTMLElement => {\n return (event.currentTarget as HTMLElement).closest(\n \".neuroglancer-segment-list-entry\",\n ) as HTMLElement;\n };\n\n const copyHandler = (event: Event) => {\n const entryElement = getEntryElement(event);\n setClipboard(entryElement.dataset.id!);\n event.stopPropagation();\n };\n\n const unmappedCopyHandler = (event: Event) => {\n const entryElement = getEntryElement(event);\n setClipboard(entryElement.dataset.unmappedId!);\n event.stopPropagation();\n };\n\n const visibleCheckboxHandler = (event: Event) => {\n const entryElement = getEntryElement(event);\n const idString = entryElement.dataset.id!;\n const id = tempObjectId;\n id.tryParseString(idString);\n const { selectedSegments, visibleSegments } =\n displayState.segmentationGroupState.value;\n const shouldBeVisible = !visibleSegments.has(id);\n if (shouldBeVisible) {\n selectedSegments.add(id);\n }\n visibleSegments.set(id, shouldBeVisible);\n event.stopPropagation();\n event.preventDefault();\n };\n\n const filterHandler = (event: Event) => {\n const entryElement = getEntryElement(event);\n const idString = entryElement.dataset.id!;\n const id = tempObjectId;\n id.tryParseString(idString);\n displayState.filterBySegmentLabel(id);\n event.stopPropagation();\n };\n\n const onMousedown = (event: MouseEvent) => {\n if (\n event.button !== 2 ||\n event.ctrlKey ||\n event.altKey ||\n event.metaKey ||\n event.shiftKey\n ) {\n return;\n }\n const entryElement = event.currentTarget as HTMLElement;\n const idString = entryElement.dataset.id!;\n const id = tempObjectId;\n id.tryParseString(idString);\n displayState.moveToSegment(id);\n };\n\n return (element: HTMLElement, template: SegmentWidgetTemplate) => {\n const { children } = element;\n const stickyChildren = children[0].children;\n element.addEventListener(\"mousedown\", onMousedown);\n const copyContainer = stickyChildren[\n template.copyContainerIndex\n ] as HTMLElement;\n if (template.unmappedCopyIndex !== -1) {\n copyContainer.children[template.unmappedCopyIndex].addEventListener(\n \"click\",\n unmappedCopyHandler,\n );\n }\n copyContainer.children[template.copyIndex].addEventListener(\n \"click\",\n copyHandler,\n );\n element.addEventListener(\"mouseenter\", onMouseEnter);\n element.addEventListener(\"mouseleave\", onMouseLeave);\n stickyChildren[template.visibleIndex].addEventListener(\n \"click\",\n visibleCheckboxHandler,\n );\n children[template.filterIndex].addEventListener(\"click\", filterHandler);\n element.addEventListener(\"action:select-position\", selectHandler);\n\n const starButton = stickyChildren[template.starIndex] as HTMLElement;\n starButton.addEventListener(\"click\", (event: MouseEvent) => {\n const entryElement = getEntryElement(event);\n const idString = entryElement.dataset.id!;\n const id = tempObjectId;\n id.tryParseString(idString);\n const { selectedSegments } = displayState.segmentationGroupState.value;\n selectedSegments.set(id, !selectedSegments.has(id));\n });\n\n const trackableRGB = new TrackableRGB(vec3.fromValues(0, 0, 0));\n trackableRGB.changed.add(() => {\n const testU = new Uint64(packColor(trackableRGB.value));\n const idString = element.dataset.id!;\n const id = tempObjectId;\n id.tryParseString(idString);\n displayState.segmentStatedColors.value.delete(id);\n displayState.segmentStatedColors.value.set(id, testU);\n });\n\n // TODO, need to register disposer?\n new ColorWidget(\n trackableRGB,\n undefined,\n children[template.colorWidgetIndex] as HTMLInputElement,\n () => {\n const idString = element.dataset.id!;\n const id = tempObjectId;\n id.tryParseString(idString);\n displayState.segmentStatedColors.value.delete(id);\n },\n false,\n );\n };\n}\n\nexport class SegmentWidgetFactory