| // Copyright 2020 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| /* eslint-disable rulesdir/no-imperative-dom-api */ |
| |
| /* |
| * Copyright (C) 2009 Joseph Pecoraro |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * |
| * 1. Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * 2. Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. |
| * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of |
| * its contributors may be used to endorse or promote products derived |
| * from this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY |
| * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
| * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
| * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY |
| * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
| * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
| * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
| * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
| * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| import type * as Common from '../../core/common/common.js'; |
| import * as UI from '../../ui/legacy/legacy.js'; |
| import * as VisualLogging from '../../ui/visual_logging/visual_logging.js'; |
| |
| import {ConsoleView} from './ConsoleView.js'; |
| |
| let consolePanelInstance: ConsolePanel; |
| |
| export class ConsolePanel extends UI.Panel.Panel { |
| private readonly view: ConsoleView; |
| constructor() { |
| super('console'); |
| this.view = ConsoleView.instance(); |
| } |
| |
| static instance(opts: { |
| forceNew: boolean|null, |
| } = {forceNew: null}): ConsolePanel { |
| const {forceNew} = opts; |
| if (!consolePanelInstance || forceNew) { |
| consolePanelInstance = new ConsolePanel(); |
| } |
| |
| return consolePanelInstance; |
| } |
| |
| static updateContextFlavor(): void { |
| const consoleView = ConsolePanel.instance().view; |
| UI.Context.Context.instance().setFlavor(ConsoleView, consoleView.isShowing() ? consoleView : null); |
| } |
| |
| override wasShown(): void { |
| super.wasShown(); |
| const wrapper = wrapperViewInstance; |
| if (wrapper?.isShowing()) { |
| UI.InspectorView.InspectorView.instance().setDrawerMinimized(true); |
| } |
| this.view.show(this.element); |
| ConsolePanel.updateContextFlavor(); |
| } |
| |
| override willHide(): void { |
| super.willHide(); |
| // The minimized drawer has 0 height, and showing Console inside may set |
| // Console's scrollTop to 0. Unminimize before calling show to avoid this. |
| UI.InspectorView.InspectorView.instance().setDrawerMinimized(false); |
| if (wrapperViewInstance) { |
| wrapperViewInstance.showViewInWrapper(); |
| } |
| ConsolePanel.updateContextFlavor(); |
| } |
| |
| override searchableView(): UI.SearchableView.SearchableView|null { |
| return ConsoleView.instance().searchableView(); |
| } |
| } |
| |
| let wrapperViewInstance: WrapperView|null = null; |
| |
| export class WrapperView extends UI.Widget.VBox { |
| private readonly view: ConsoleView; |
| |
| private constructor() { |
| super(); |
| this.view = ConsoleView.instance(); |
| this.element.setAttribute('jslog', `${VisualLogging.panel('console').track({resize: true})}`); |
| } |
| |
| static instance(): WrapperView { |
| if (!wrapperViewInstance) { |
| wrapperViewInstance = new WrapperView(); |
| } |
| return wrapperViewInstance; |
| } |
| |
| override wasShown(): void { |
| if (!ConsolePanel.instance().isShowing()) { |
| this.showViewInWrapper(); |
| } else { |
| UI.InspectorView.InspectorView.instance().setDrawerMinimized(true); |
| } |
| ConsolePanel.updateContextFlavor(); |
| } |
| |
| override willHide(): void { |
| UI.InspectorView.InspectorView.instance().setDrawerMinimized(false); |
| ConsolePanel.updateContextFlavor(); |
| } |
| |
| showViewInWrapper(): void { |
| this.view.show(this.element); |
| } |
| } |
| |
| export class ConsoleRevealer implements Common.Revealer.Revealer<Common.Console.Console> { |
| async reveal(_object: Common.Console.Console): Promise<void> { |
| const consoleView = ConsoleView.instance(); |
| if (consoleView.isShowing()) { |
| consoleView.focus(); |
| return; |
| } |
| await UI.ViewManager.ViewManager.instance().showView('console-view'); |
| } |
| } |