All Downloads are FREE. Search and download functionalities are using the official Maven repository.

META-INF.dirigible.dev-tools.sources.SourcesNavigator.js Maven / Gradle / Ivy

/*
 * Copyright (C) 2011 Google Inc. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are
 * met:
 *
 *     * Redistributions of source code must retain the above copyright
 * notice, this list of conditions and the following disclaimer.
 *     * 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.
 *     * Neither the name of Google Inc. 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 THE COPYRIGHT HOLDERS AND 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 THE COPYRIGHT
 * OWNER OR 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 * as Common from '../common/common.js';
import * as Host from '../host/host.js';
import * as Persistence from '../persistence/persistence.js';
import * as SDK from '../sdk/sdk.js';
import * as Snippets from '../snippets/snippets.js';
import * as UI from '../ui/ui.js';
import * as Workspace from '../workspace/workspace.js';

import {NavigatorUISourceCodeTreeNode, NavigatorView} from './NavigatorView.js';  // eslint-disable-line no-unused-vars

/**
 * @unrestricted
 */
export class NetworkNavigatorView extends NavigatorView {
  constructor() {
    super();
    SDK.SDKModel.TargetManager.instance().addEventListener(
        SDK.SDKModel.Events.InspectedURLChanged, this._inspectedURLChanged, this);

    // Record the sources tool load time after the file navigator has loaded.
    Host.userMetrics.panelLoaded('sources', 'DevTools.Launch.Sources');
  }

  /**
   * @override
   * @param {!Workspace.Workspace.Project} project
   * @return {boolean}
   */
  acceptProject(project) {
    return project.type() === Workspace.Workspace.projectTypes.Network;
  }

  /**
   * @param {!Common.EventTarget.EventTargetEvent} event
   */
  _inspectedURLChanged(event) {
    const mainTarget = SDK.SDKModel.TargetManager.instance().mainTarget();
    if (event.data !== mainTarget) {
      return;
    }
    const inspectedURL = mainTarget && mainTarget.inspectedURL();
    if (!inspectedURL) {
      return;
    }
    for (const uiSourceCode of this.workspace().uiSourceCodes()) {
      if (this.acceptProject(uiSourceCode.project()) && uiSourceCode.url() === inspectedURL) {
        this.revealUISourceCode(uiSourceCode, true);
      }
    }
  }

  /**
   * @override
   * @param {!Workspace.UISourceCode.UISourceCode} uiSourceCode
   */
  uiSourceCodeAdded(uiSourceCode) {
    const mainTarget = SDK.SDKModel.TargetManager.instance().mainTarget();
    const inspectedURL = mainTarget && mainTarget.inspectedURL();
    if (!inspectedURL) {
      return;
    }
    if (uiSourceCode.url() === inspectedURL) {
      this.revealUISourceCode(uiSourceCode, true);
    }
  }
}

/**
 * @unrestricted
 */
export class FilesNavigatorView extends NavigatorView {
  constructor() {
    super();
    const placeholder = new UI.EmptyWidget.EmptyWidget('');
    this.setPlaceholder(placeholder);
    placeholder.appendParagraph().appendChild(UI.Fragment.html`
      
${ls`Sync changes in DevTools with the local filesystem`}

${UI.XLink.XLink.create('https://developers.google.com/web/tools/chrome-devtools/workspaces/', ls`Learn more`)} `); const toolbar = new UI.Toolbar.Toolbar('navigator-toolbar'); toolbar.appendItemsAtLocation('files-navigator-toolbar').then(() => { if (!toolbar.empty()) { this.contentElement.insertBefore(toolbar.element, this.contentElement.firstChild); } }); } /** * @override * @param {!Workspace.Workspace.Project} project * @return {boolean} */ acceptProject(project) { return project.type() === Workspace.Workspace.projectTypes.FileSystem && Persistence.FileSystemWorkspaceBinding.FileSystemWorkspaceBinding.fileSystemType(project) !== 'overrides' && !Snippets.ScriptSnippetFileSystem.isSnippetsProject(project); } /** * @override * @param {!Event} event */ handleContextMenu(event) { const contextMenu = new UI.ContextMenu.ContextMenu(event); contextMenu.defaultSection().appendAction('sources.add-folder-to-workspace', undefined, true); contextMenu.show(); } } export class OverridesNavigatorView extends NavigatorView { constructor() { super(); const placeholder = new UI.EmptyWidget.EmptyWidget(''); this.setPlaceholder(placeholder); placeholder.appendParagraph().appendChild(UI.Fragment.html`
${ls`Override page assets with files from a local folder`}

${UI.XLink.XLink.create('https://developers.google.com/web/updates/2018/01/devtools#overrides', ls`Learn more`)} `); this._toolbar = new UI.Toolbar.Toolbar('navigator-toolbar'); this.contentElement.insertBefore(this._toolbar.element, this.contentElement.firstChild); self.Persistence.networkPersistenceManager.addEventListener( Persistence.NetworkPersistenceManager.Events.ProjectChanged, this._updateProjectAndUI, this); this.workspace().addEventListener(Workspace.Workspace.Events.ProjectAdded, this._onProjectAddOrRemoved, this); this.workspace().addEventListener(Workspace.Workspace.Events.ProjectRemoved, this._onProjectAddOrRemoved, this); this._updateProjectAndUI(); } /** * @param {!Common.EventTarget.EventTargetEvent} event */ _onProjectAddOrRemoved(event) { const project = /** @type {!Workspace.Workspace.Project} */ (event.data); if (project && project.type() === Workspace.Workspace.projectTypes.FileSystem && Persistence.FileSystemWorkspaceBinding.FileSystemWorkspaceBinding.fileSystemType(project) !== 'overrides') { return; } this._updateUI(); } _updateProjectAndUI() { this.reset(); const project = self.Persistence.networkPersistenceManager.project(); if (project) { this.tryAddProject(project); } this._updateUI(); } _updateUI() { this._toolbar.removeToolbarItems(); const project = self.Persistence.networkPersistenceManager.project(); if (project) { const enableCheckbox = new UI.Toolbar.ToolbarSettingCheckbox( Common.Settings.Settings.instance().moduleSetting('persistenceNetworkOverridesEnabled')); this._toolbar.appendToolbarItem(enableCheckbox); this._toolbar.appendToolbarItem(new UI.Toolbar.ToolbarSeparator(true)); const clearButton = new UI.Toolbar.ToolbarButton(Common.UIString.UIString('Clear configuration'), 'largeicon-clear'); clearButton.addEventListener(UI.Toolbar.ToolbarButton.Events.Click, () => { project.remove(); }); this._toolbar.appendToolbarItem(clearButton); return; } const title = Common.UIString.UIString('Select folder for overrides'); const setupButton = new UI.Toolbar.ToolbarButton(title, 'largeicon-add', title); setupButton.addEventListener(UI.Toolbar.ToolbarButton.Events.Click, event => { this._setupNewWorkspace(); }, this); this._toolbar.appendToolbarItem(setupButton); } async _setupNewWorkspace() { const fileSystem = await Persistence.IsolatedFileSystemManager.IsolatedFileSystemManager.instance().addFileSystem('overrides'); if (!fileSystem) { return; } Common.Settings.Settings.instance().moduleSetting('persistenceNetworkOverridesEnabled').set(true); } /** * @override * @param {!Workspace.Workspace.Project} project * @return {boolean} */ acceptProject(project) { return project === self.Persistence.networkPersistenceManager.project(); } } /** * @unrestricted */ export class ContentScriptsNavigatorView extends NavigatorView { constructor() { super(); const placeholder = new UI.EmptyWidget.EmptyWidget(''); this.setPlaceholder(placeholder); placeholder.appendParagraph().appendChild(UI.Fragment.html`
${ls`Content scripts served by extensions appear here`}

${UI.XLink.XLink.create('https://developer.chrome.com/extensions/content_scripts', ls`Learn more`)} `); } /** * @override * @param {!Workspace.Workspace.Project} project * @return {boolean} */ acceptProject(project) { return project.type() === Workspace.Workspace.projectTypes.ContentScripts; } } /** * @unrestricted */ export class SnippetsNavigatorView extends NavigatorView { constructor() { super(); const placeholder = new UI.EmptyWidget.EmptyWidget(''); this.setPlaceholder(placeholder); placeholder.appendParagraph().appendChild(UI.Fragment.html`
${ls`Create and save code snippets for later reuse`}

${ UI.XLink.XLink.create( 'https://developers.google.com/web/tools/chrome-devtools/javascript/snippets', ls`Learn more`)} `); const toolbar = new UI.Toolbar.Toolbar('navigator-toolbar'); const newButton = new UI.Toolbar.ToolbarButton(ls`New snippet`, 'largeicon-add', Common.UIString.UIString('New snippet')); newButton.addEventListener(UI.Toolbar.ToolbarButton.Events.Click, event => { this.create(self.Snippets.project, ''); }); toolbar.appendToolbarItem(newButton); this.contentElement.insertBefore(toolbar.element, this.contentElement.firstChild); } /** * @override * @param {!Workspace.Workspace.Project} project * @return {boolean} */ acceptProject(project) { return Snippets.ScriptSnippetFileSystem.isSnippetsProject(project); } /** * @override * @param {!Event} event */ handleContextMenu(event) { const contextMenu = new UI.ContextMenu.ContextMenu(event); contextMenu.headerSection().appendItem(ls`Create new snippet`, () => this.create(self.Snippets.project, '')); contextMenu.show(); } /** * @override * @param {!Event} event * @param {!NavigatorUISourceCodeTreeNode} node */ handleFileContextMenu(event, node) { const uiSourceCode = node.uiSourceCode(); const contextMenu = new UI.ContextMenu.ContextMenu(event); contextMenu.headerSection().appendItem( Common.UIString.UIString('Run'), () => Snippets.ScriptSnippetFileSystem.evaluateScriptSnippet(uiSourceCode)); contextMenu.editSection().appendItem(Common.UIString.UIString('Rename…'), () => this.rename(node, false)); contextMenu.editSection().appendItem( Common.UIString.UIString('Remove'), () => uiSourceCode.project().deleteFile(uiSourceCode)); contextMenu.saveSection().appendItem( Common.UIString.UIString('Save as...'), this._handleSaveAs.bind(this, uiSourceCode)); contextMenu.show(); } /** * @param {!Workspace.UISourceCode.UISourceCode} uiSourceCode */ async _handleSaveAs(uiSourceCode) { uiSourceCode.commitWorkingCopy(); const {content} = await uiSourceCode.requestContent(); self.Workspace.fileManager.save(uiSourceCode.url(), content || '', true); self.Workspace.fileManager.close(uiSourceCode.url()); } } /** * @implements {UI.ActionDelegate.ActionDelegate} */ export class ActionDelegate { /** * @override * @param {!UI.Context.Context} context * @param {string} actionId * @return {boolean} */ handleAction(context, actionId) { switch (actionId) { case 'sources.create-snippet': self.Snippets.project.createFile('', null, '').then(uiSourceCode => Common.Revealer.reveal(uiSourceCode)); return true; case 'sources.add-folder-to-workspace': Persistence.IsolatedFileSystemManager.IsolatedFileSystemManager.instance().addFileSystem(); return true; } return false; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy