/** * 3D Foundation Project * Copyright 2025 Smithsonian Institution * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import SystemView, { customElement, html } from "@ff/scene/ui/SystemView"; import "./DocumentList"; import "./NodeTree"; import CVTaskProvider from "../../components/CVTaskProvider"; //////////////////////////////////////////////////////////////////////////////// @customElement("sv-navigator-panel") export default class NavigatorPanel extends SystemView { protected get taskProvider() { return this.system.getMainComponent(CVTaskProvider); } protected firstConnected() { this.classList.add("sv-panel", "sv-navigator-panel"); } protected connected() { this.taskProvider.ins.mode.on("value", this.performUpdate, this); } protected disconnected() { this.taskProvider.ins.mode.off("value", this.performUpdate, this); } protected render() { const system = this.system; const expertMode = this.taskProvider.expertMode; const documentList = expertMode ? html`