mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-20 01:25:37 -05:00
117 lines
5.3 KiB
TypeScript
117 lines
5.3 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import * as vscode from 'vscode';
|
|
import { WorkspaceTreeDataProvider } from './common/workspaceTreeDataProvider';
|
|
import { WorkspaceService } from './services/workspaceService';
|
|
import { WorkspaceTreeItem, IExtension } from 'dataworkspace';
|
|
import { DataWorkspaceExtension } from './common/dataWorkspaceExtension';
|
|
import { NewProjectDialog } from './dialogs/newProjectDialog';
|
|
import { browseForProject, OpenExistingDialog } from './dialogs/openExistingDialog';
|
|
import { IconPathHelper } from './common/iconHelper';
|
|
import { ProjectDashboard } from './dialogs/projectDashboard';
|
|
import { getAzdataApi } from './common/utils';
|
|
import { createNewProjectWithQuickpick } from './dialogs/newProjectQuickpick';
|
|
import Logger from './common/logger';
|
|
import { TelemetryReporter } from './common/telemetry';
|
|
import { noProjectProvidingExtensionsInstalled } from './common/constants';
|
|
|
|
export async function activate(context: vscode.ExtensionContext): Promise<IExtension> {
|
|
const startTime = new Date().getTime();
|
|
Logger.log(`Starting Data Workspace activate()`);
|
|
|
|
const azDataApiStartTime = new Date().getTime();
|
|
const azdataApi = getAzdataApi();
|
|
void vscode.commands.executeCommand('setContext', 'azdataAvailable', !!azdataApi);
|
|
Logger.log(`Setting azdataAvailable took ${new Date().getTime() - azDataApiStartTime}ms`);
|
|
|
|
const workspaceServiceConstructorStartTime = new Date().getTime();
|
|
const workspaceService = new WorkspaceService();
|
|
Logger.log(`WorkspaceService constructor took ${new Date().getTime() - workspaceServiceConstructorStartTime}ms`);
|
|
|
|
const workspaceTreeDataProviderStartTime = new Date().getTime();
|
|
const workspaceTreeDataProvider = new WorkspaceTreeDataProvider(workspaceService);
|
|
context.subscriptions.push(vscode.workspace.onDidChangeWorkspaceFolders(async () => {
|
|
await workspaceTreeDataProvider.refresh();
|
|
}));
|
|
Logger.log(`WorkspaceTreeDataProvider constructor took ${new Date().getTime() - workspaceTreeDataProviderStartTime}ms`);
|
|
|
|
const dataWorkspaceExtensionStartTime = new Date().getTime();
|
|
const dataWorkspaceExtension = new DataWorkspaceExtension(workspaceService);
|
|
Logger.log(`DataWorkspaceExtension constructor took ${new Date().getTime() - dataWorkspaceExtensionStartTime}ms`);
|
|
|
|
const registerCommandStartTime = new Date().getTime();
|
|
context.subscriptions.push(vscode.commands.registerCommand('projects.new', async () => {
|
|
// Make sure all project providing extensions are activated to be sure the project templates show up
|
|
await workspaceService.ensureProviderExtensionLoaded(undefined, true);
|
|
|
|
if (!workspaceService.isProjectProviderAvailable) {
|
|
void vscode.window.showErrorMessage(noProjectProvidingExtensionsInstalled);
|
|
return;
|
|
}
|
|
|
|
if (azdataApi) {
|
|
const dialog = new NewProjectDialog(workspaceService);
|
|
await dialog.open();
|
|
} else {
|
|
await createNewProjectWithQuickpick(workspaceService);
|
|
}
|
|
}));
|
|
|
|
context.subscriptions.push(vscode.commands.registerCommand('projects.openExisting', async () => {
|
|
// Make sure all project providing extensions are activated so that all supported project types show up in the file filter
|
|
await workspaceService.ensureProviderExtensionLoaded(undefined, true);
|
|
|
|
if (!workspaceService.isProjectProviderAvailable) {
|
|
void vscode.window.showErrorMessage(noProjectProvidingExtensionsInstalled);
|
|
return;
|
|
}
|
|
|
|
if (azdataApi) {
|
|
const dialog = new OpenExistingDialog(workspaceService);
|
|
await dialog.open();
|
|
} else {
|
|
const projectFileUri = await browseForProject(workspaceService);
|
|
if (!projectFileUri) {
|
|
return;
|
|
}
|
|
await workspaceService.addProjectsToWorkspace([projectFileUri]);
|
|
}
|
|
}));
|
|
|
|
context.subscriptions.push(vscode.commands.registerCommand('dataworkspace.refresh', async () => {
|
|
await workspaceTreeDataProvider.refresh();
|
|
}));
|
|
|
|
context.subscriptions.push(vscode.commands.registerCommand('dataworkspace.close', () => {
|
|
return vscode.commands.executeCommand('workbench.action.closeFolder');
|
|
}));
|
|
|
|
context.subscriptions.push(vscode.commands.registerCommand('projects.removeProject', async (treeItem: WorkspaceTreeItem) => {
|
|
await workspaceService.removeProject(vscode.Uri.file(treeItem.element.project.projectFilePath));
|
|
}));
|
|
|
|
context.subscriptions.push(vscode.commands.registerCommand('projects.manageProject', async (treeItem: WorkspaceTreeItem) => {
|
|
const dashboard = new ProjectDashboard(workspaceService, treeItem);
|
|
await dashboard.showDashboard();
|
|
}));
|
|
Logger.log(`Registering commands took ${new Date().getTime() - registerCommandStartTime}ms`);
|
|
|
|
context.subscriptions.push(vscode.extensions.onDidChange(() => {
|
|
workspaceService.updateIfProjectProviderAvailable();
|
|
}));
|
|
|
|
const iconPathHelperTime = new Date().getTime();
|
|
IconPathHelper.setExtensionContext(context);
|
|
Logger.log(`IconPathHelper took ${new Date().getTime() - iconPathHelperTime}ms`);
|
|
|
|
context.subscriptions.push(TelemetryReporter);
|
|
Logger.log(`Finished activating Data Workspace extension. Total time = ${new Date().getTime() - startTime}ms`);
|
|
return Promise.resolve(dataWorkspaceExtension);
|
|
}
|
|
|
|
export function deactivate(): void {
|
|
}
|