/
tsconfig.ts
50 lines (45 loc) · 1.7 KB
/
tsconfig.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import * as vscode from 'vscode';
import { BaseLanguageClient } from 'vscode-languageclient';
import * as shared from '@volar/shared';
import { posix as path } from 'path';
import { takeOverModeEnabled } from '../common';
export async function register(cmd: string, context: vscode.ExtensionContext, languageClient: BaseLanguageClient) {
const statusBar = vscode.window.createStatusBarItem(vscode.StatusBarAlignment.Right);
let currentTsconfig = '';
updateStatusBar();
vscode.window.onDidChangeActiveTextEditor(updateStatusBar, undefined, context.subscriptions);
vscode.commands.registerCommand(cmd, async () => {
const document = await vscode.workspace.openTextDocument(currentTsconfig);
await vscode.window.showTextDocument(document);
});
async function updateStatusBar() {
if (
vscode.window.activeTextEditor?.document.languageId !== 'vue'
&& vscode.window.activeTextEditor?.document.languageId !== 'markdown'
&& vscode.window.activeTextEditor?.document.languageId !== 'html'
&& !(
takeOverModeEnabled()
&& vscode.window.activeTextEditor
&& ['javascript', 'typescript', 'javascriptreact', 'typescriptreact'].includes(vscode.window.activeTextEditor.document.languageId)
)
) {
statusBar.hide();
}
else {
const tsconfig = await languageClient.sendRequest(
shared.GetMatchTsConfigRequest.type,
languageClient.code2ProtocolConverter.asTextDocumentIdentifier(vscode.window.activeTextEditor.document),
);
if (tsconfig) {
statusBar.text = path.relative(vscode.workspace.rootPath!, tsconfig);
statusBar.command = cmd;
currentTsconfig = tsconfig;
}
else {
statusBar.text = 'No tsconfig';
statusBar.command = undefined;
}
statusBar.show();
}
}
}