awa
This commit is contained in:
13
_internal/editor/esm/vs/platform/opener/browser/link.css
Normal file
13
_internal/editor/esm/vs/platform/opener/browser/link.css
Normal file
@@ -0,0 +1,13 @@
|
||||
/*---------------------------------------------------------------------------------------------
|
||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||
* Licensed under the MIT License. See License.txt in the project root for license information.
|
||||
*--------------------------------------------------------------------------------------------*/
|
||||
|
||||
.monaco-link {
|
||||
color: var(--vscode-textLink-foreground);
|
||||
}
|
||||
|
||||
.monaco-link:hover {
|
||||
color: var(--vscode-textLink-activeForeground);
|
||||
}
|
||||
|
||||
94
_internal/editor/esm/vs/platform/opener/browser/link.js
Normal file
94
_internal/editor/esm/vs/platform/opener/browser/link.js
Normal file
@@ -0,0 +1,94 @@
|
||||
/*---------------------------------------------------------------------------------------------
|
||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||
* Licensed under the MIT License. See License.txt in the project root for license information.
|
||||
*--------------------------------------------------------------------------------------------*/
|
||||
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
||||
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
||||
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
||||
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
||||
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
||||
};
|
||||
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
||||
return function (target, key) { decorator(target, key, paramIndex); }
|
||||
};
|
||||
import { $, append, EventHelper } from '../../../base/browser/dom.js';
|
||||
import { DomEmitter } from '../../../base/browser/event.js';
|
||||
import { StandardKeyboardEvent } from '../../../base/browser/keyboardEvent.js';
|
||||
import { EventType as TouchEventType, Gesture } from '../../../base/browser/touch.js';
|
||||
import { Event } from '../../../base/common/event.js';
|
||||
import { Disposable } from '../../../base/common/lifecycle.js';
|
||||
import { IOpenerService } from '../common/opener.js';
|
||||
import './link.css';
|
||||
import { getDefaultHoverDelegate } from '../../../base/browser/ui/hover/hoverDelegateFactory.js';
|
||||
import { IHoverService } from '../../hover/browser/hover.js';
|
||||
let Link = class Link extends Disposable {
|
||||
get enabled() {
|
||||
return this._enabled;
|
||||
}
|
||||
set enabled(enabled) {
|
||||
if (enabled) {
|
||||
this.el.setAttribute('aria-disabled', 'false');
|
||||
this.el.tabIndex = 0;
|
||||
this.el.style.pointerEvents = 'auto';
|
||||
this.el.style.opacity = '1';
|
||||
this.el.style.cursor = 'pointer';
|
||||
this._enabled = false;
|
||||
}
|
||||
else {
|
||||
this.el.setAttribute('aria-disabled', 'true');
|
||||
this.el.tabIndex = -1;
|
||||
this.el.style.pointerEvents = 'none';
|
||||
this.el.style.opacity = '0.4';
|
||||
this.el.style.cursor = 'default';
|
||||
this._enabled = true;
|
||||
}
|
||||
this._enabled = enabled;
|
||||
}
|
||||
constructor(container, _link, options = {}, _hoverService, openerService) {
|
||||
super();
|
||||
this._link = _link;
|
||||
this._hoverService = _hoverService;
|
||||
this._enabled = true;
|
||||
this.el = append(container, $('a.monaco-link', {
|
||||
tabIndex: _link.tabIndex ?? 0,
|
||||
href: _link.href,
|
||||
}, _link.label));
|
||||
this.hoverDelegate = options.hoverDelegate ?? getDefaultHoverDelegate('mouse');
|
||||
this.setTooltip(_link.title);
|
||||
this.el.setAttribute('role', 'button');
|
||||
const onClickEmitter = this._register(new DomEmitter(this.el, 'click'));
|
||||
const onKeyPress = this._register(new DomEmitter(this.el, 'keypress'));
|
||||
const onEnterPress = Event.chain(onKeyPress.event, $ => $.map(e => new StandardKeyboardEvent(e))
|
||||
.filter(e => e.keyCode === 3 /* KeyCode.Enter */));
|
||||
const onTap = this._register(new DomEmitter(this.el, TouchEventType.Tap)).event;
|
||||
this._register(Gesture.addTarget(this.el));
|
||||
const onOpen = Event.any(onClickEmitter.event, onEnterPress, onTap);
|
||||
this._register(onOpen(e => {
|
||||
if (!this.enabled) {
|
||||
return;
|
||||
}
|
||||
EventHelper.stop(e, true);
|
||||
if (options?.opener) {
|
||||
options.opener(this._link.href);
|
||||
}
|
||||
else {
|
||||
openerService.open(this._link.href, { allowCommands: true });
|
||||
}
|
||||
}));
|
||||
this.enabled = true;
|
||||
}
|
||||
setTooltip(title) {
|
||||
if (!this.hover && title) {
|
||||
this.hover = this._register(this._hoverService.setupManagedHover(this.hoverDelegate, this.el, title));
|
||||
}
|
||||
else if (this.hover) {
|
||||
this.hover.update(title);
|
||||
}
|
||||
}
|
||||
};
|
||||
Link = __decorate([
|
||||
__param(3, IHoverService),
|
||||
__param(4, IOpenerService)
|
||||
], Link);
|
||||
export { Link };
|
||||
//# sourceMappingURL=link.js.map
|
||||
File diff suppressed because one or more lines are too long
41
_internal/editor/esm/vs/platform/opener/common/opener.js
Normal file
41
_internal/editor/esm/vs/platform/opener/common/opener.js
Normal file
@@ -0,0 +1,41 @@
|
||||
/*---------------------------------------------------------------------------------------------
|
||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||
* Licensed under the MIT License. See License.txt in the project root for license information.
|
||||
*--------------------------------------------------------------------------------------------*/
|
||||
import { createDecorator } from '../../instantiation/common/instantiation.js';
|
||||
export const IOpenerService = createDecorator('openerService');
|
||||
/**
|
||||
* Encodes selection into the `URI`.
|
||||
*
|
||||
* IMPORTANT: you MUST use `extractSelection` to separate the selection
|
||||
* again from the original `URI` before passing the `URI` into any
|
||||
* component that is not aware of selections.
|
||||
*/
|
||||
export function withSelection(uri, selection) {
|
||||
return uri.with({ fragment: `${selection.startLineNumber},${selection.startColumn}${selection.endLineNumber ? `-${selection.endLineNumber}${selection.endColumn ? `,${selection.endColumn}` : ''}` : ''}` });
|
||||
}
|
||||
/**
|
||||
* file:///some/file.js#73
|
||||
* file:///some/file.js#L73
|
||||
* file:///some/file.js#73,84
|
||||
* file:///some/file.js#L73,84
|
||||
* file:///some/file.js#73-83
|
||||
* file:///some/file.js#L73-L83
|
||||
* file:///some/file.js#73,84-83,52
|
||||
* file:///some/file.js#L73,84-L83,52
|
||||
*/
|
||||
export function extractSelection(uri) {
|
||||
let selection = undefined;
|
||||
const match = /^L?(\d+)(?:,(\d+))?(-L?(\d+)(?:,(\d+))?)?/.exec(uri.fragment);
|
||||
if (match) {
|
||||
selection = {
|
||||
startLineNumber: parseInt(match[1]),
|
||||
startColumn: match[2] ? parseInt(match[2]) : 1,
|
||||
endLineNumber: match[4] ? parseInt(match[4]) : undefined,
|
||||
endColumn: match[4] ? (match[5] ? parseInt(match[5]) : 1) : undefined
|
||||
};
|
||||
uri = uri.with({ fragment: '' });
|
||||
}
|
||||
return { selection, uri };
|
||||
}
|
||||
//# sourceMappingURL=opener.js.map
|
||||
File diff suppressed because one or more lines are too long
Reference in New Issue
Block a user