blob: c2ecb204b6183a7e258581454121fce997bc8709 [file] [log] [blame]
// Copyright 2016 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_underscored_properties */
import * as Common from '../common/common.js';
import * as Components from '../components/components.js';
import * as i18n from '../i18n/i18n.js';
import * as Platform from '../platform/platform.js';
import * as UI from '../ui/ui.js';
import * as Workspace from '../workspace/workspace.js';
import {FileSystemWorkspaceBinding} from './FileSystemWorkspaceBinding.js';
import {NetworkPersistenceManager} from './NetworkPersistenceManager.js';
import type {PersistenceBinding} from './PersistenceImpl.js';
import {Events, PersistenceImpl} from './PersistenceImpl.js';
export const UIStrings = {
/**
*@description Text in Persistence Utils of the Workspace settings in Settings
*@example {example.url} PH1
*/
linkedToSourceMapS: 'Linked to source map: {PH1}',
/**
*@description Text to show something is linked to another
*@example {example.url} PH1
*/
linkedToS: 'Linked to {PH1}',
};
const str_ = i18n.i18n.registerUIStrings('persistence/PersistenceUtils.ts', UIStrings);
const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
export class PersistenceUtils {
static tooltipForUISourceCode(uiSourceCode: Workspace.UISourceCode.UISourceCode): string {
const binding = PersistenceImpl.instance().binding(uiSourceCode);
if (!binding) {
return '';
}
if (uiSourceCode === binding.network) {
return FileSystemWorkspaceBinding.tooltipForUISourceCode(binding.fileSystem);
}
if (binding.network.contentType().isFromSourceMap()) {
return i18nString(
UIStrings.linkedToSourceMapS, {PH1: Platform.StringUtilities.trimMiddle(binding.network.url(), 150)});
}
return i18nString(UIStrings.linkedToS, {PH1: Platform.StringUtilities.trimMiddle(binding.network.url(), 150)});
}
static iconForUISourceCode(uiSourceCode: Workspace.UISourceCode.UISourceCode): UI.Icon.Icon|null {
const binding = PersistenceImpl.instance().binding(uiSourceCode);
if (binding) {
if (!binding.fileSystem.url().startsWith('file://')) {
return null;
}
const icon = UI.Icon.Icon.create('mediumicon-file-sync');
UI.Tooltip.Tooltip.install(icon, PersistenceUtils.tooltipForUISourceCode(binding.network));
// TODO(allada) This will not work properly with dark theme.
if (NetworkPersistenceManager.instance().project() === binding.fileSystem.project()) {
icon.style.filter = 'hue-rotate(160deg)';
}
return icon;
}
if (uiSourceCode.project().type() !== Workspace.Workspace.projectTypes.FileSystem ||
!uiSourceCode.url().startsWith('file://')) {
return null;
}
const icon = UI.Icon.Icon.create('mediumicon-file');
UI.Tooltip.Tooltip.install(icon, PersistenceUtils.tooltipForUISourceCode(uiSourceCode));
return icon;
}
}
export class LinkDecorator extends Common.ObjectWrapper.ObjectWrapper implements Components.Linkifier.LinkDecorator {
constructor(persistence: PersistenceImpl) {
super();
persistence.addEventListener(Events.BindingCreated, this._bindingChanged, this);
persistence.addEventListener(Events.BindingRemoved, this._bindingChanged, this);
}
_bindingChanged(event: Common.EventTarget.EventTargetEvent): void {
const binding = event.data as PersistenceBinding;
this.dispatchEventToListeners(Components.Linkifier.LinkDecorator.Events.LinkIconChanged, binding.network);
}
linkIcon(uiSourceCode: Workspace.UISourceCode.UISourceCode): UI.Icon.Icon|null {
return PersistenceUtils.iconForUISourceCode(uiSourceCode);
}
}