mirror of https://github.com/coder/code-server.git
75 lines
2.3 KiB
TypeScript
75 lines
2.3 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|||
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|||
*--------------------------------------------------------------------------------------------*/
|
|||
|
|||
import * as vscode from 'vscode';
|
|||
import * as nls from 'vscode-nls';
|
|||
import { SimpleBrowserManager } from './simpleBrowserManager';
|
|||
|
|||
declare const URL: typeof import('url').URL;
|
|||
|
|||
const localize = nls.loadMessageBundle();
|
|||
|
|||
const openApiCommand = 'simpleBrowser.api.open';
|
|||
const showCommand = 'simpleBrowser.show';
|
|||
|
|||
const enabledHosts = new Set<string>([
|
|||
'localhost',
|
|||
'127.0.0.1'
|
|||
]);
|
|||
|
|||
const openerId = 'simpleBrowser.open';
|
|||
|
|||
export function activate(context: vscode.ExtensionContext) {
|
|||
|
|||
const manager = new SimpleBrowserManager(context.extensionUri);
|
|||
context.subscriptions.push(manager);
|
|||
|
|||
context.subscriptions.push(vscode.commands.registerCommand(showCommand, async (url?: string) => {
|
|||
if (!url) {
|
|||
url = await vscode.window.showInputBox({
|
|||
placeHolder: localize('simpleBrowser.show.placeholder', "https://example.com"),
|
|||
prompt: localize('simpleBrowser.show.prompt', "Enter url to visit")
|
|||
});
|
|||
}
|
|||
|
|||
if (url) {
|
|||
manager.show(url);
|
|||
}
|
|||
}));
|
|||
|
|||
context.subscriptions.push(vscode.commands.registerCommand(openApiCommand, (url: vscode.Uri, showOptions?: {
|
|||
preserveFocus?: boolean,
|
|||
viewColumn: vscode.ViewColumn,
|
|||
}) => {
|
|||
manager.show(url.toString(), showOptions);
|
|||
}));
|
|||
|
|||
context.subscriptions.push(vscode.window.registerExternalUriOpener(openerId, {
|
|||
canOpenExternalUri(uri: vscode.Uri) {
|
|||
const originalUri = new URL(uri.toString());
|
|||
if (enabledHosts.has(originalUri.hostname)) {
|
|||
return isWeb()
|
|||
? vscode.ExternalUriOpenerPriority.Default
|
|||
: vscode.ExternalUriOpenerPriority.Option;
|
|||
}
|
|||
|
|||
return vscode.ExternalUriOpenerPriority.None;
|
|||
},
|
|||
openExternalUri(resolveUri: vscode.Uri) {
|
|||
return manager.show(resolveUri.toString(), {
|
|||
viewColumn: vscode.window.activeTextEditor ? vscode.ViewColumn.Beside : vscode.ViewColumn.Active
|
|||
});
|
|||
}
|
|||
}, {
|
|||
schemes: ['http', 'https'],
|
|||
label: localize('openTitle', "Open in simple browser"),
|
|||
}));
|
|||
}
|
|||
|
|||
function isWeb(): boolean {
|
|||
// @ts-expect-error
|
|||
return typeof navigator !== 'undefined' && vscode.env.uiKind === vscode.UIKind.Web;
|
|||
}
|