mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-01-22 17:22:59 -05:00
* Removing database name from server connection and adding required asterisk to database dropdowns * also remove database name in flat file import wizard
173 lines
5.7 KiB
TypeScript
173 lines
5.7 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
'use strict';
|
|
|
|
import * as azdata from 'azdata';
|
|
import * as nls from 'vscode-nls';
|
|
import * as vscode from 'vscode';
|
|
import * as os from 'os';
|
|
import * as path from 'path';
|
|
import { DataTierApplicationWizard } from '../dataTierApplicationWizard';
|
|
import { DacFxDataModel } from './models';
|
|
import { BasePage } from './basePage';
|
|
import { sanitizeStringForFilename } from './utils';
|
|
|
|
const localize = nls.loadMessageBundle();
|
|
|
|
export abstract class DacFxConfigPage extends BasePage {
|
|
|
|
protected readonly wizardPage: azdata.window.WizardPage;
|
|
protected readonly instance: DataTierApplicationWizard;
|
|
protected readonly model: DacFxDataModel;
|
|
protected readonly view: azdata.ModelView;
|
|
protected serverDropdown: azdata.DropDownComponent;
|
|
protected databaseTextBox: azdata.InputBoxComponent;
|
|
protected databaseDropdown: azdata.DropDownComponent;
|
|
protected databaseLoader: azdata.LoadingComponent;
|
|
protected fileTextBox: azdata.InputBoxComponent;
|
|
protected fileButton: azdata.ButtonComponent;
|
|
protected fileExtension: string;
|
|
|
|
protected constructor(instance: DataTierApplicationWizard, wizardPage: azdata.window.WizardPage, model: DacFxDataModel, view: azdata.ModelView) {
|
|
super();
|
|
this.instance = instance;
|
|
this.wizardPage = wizardPage;
|
|
this.model = model;
|
|
this.view = view;
|
|
}
|
|
|
|
public setupNavigationValidator() {
|
|
this.instance.registerNavigationValidator(() => {
|
|
return true;
|
|
});
|
|
}
|
|
|
|
protected async createServerDropdown(isTargetServer: boolean): Promise<azdata.FormComponent> {
|
|
this.serverDropdown = this.view.modelBuilder.dropDown().withProperties({
|
|
required: true
|
|
}).component();
|
|
|
|
// Handle server changes
|
|
this.serverDropdown.onValueChanged(async () => {
|
|
this.model.server = (this.serverDropdown.value as ConnectionDropdownValue).connection;
|
|
this.model.serverName = (this.serverDropdown.value as ConnectionDropdownValue).displayName;
|
|
await this.populateDatabaseDropdown();
|
|
});
|
|
|
|
let targetServerTitle = localize('dacFx.targetServerDropdownTitle', 'Target Server');
|
|
let sourceServerTitle = localize('dacFx.sourceServerDropdownTitle', 'Source Server');
|
|
|
|
return {
|
|
component: this.serverDropdown,
|
|
title: isTargetServer ? targetServerTitle : sourceServerTitle
|
|
};
|
|
}
|
|
|
|
protected async populateServerDropdown(): Promise<boolean> {
|
|
let values = await this.getServerValues();
|
|
if (values === undefined) {
|
|
return false;
|
|
}
|
|
|
|
this.model.server = values[0].connection;
|
|
this.model.serverName = values[0].displayName;
|
|
|
|
this.serverDropdown.updateProperties({
|
|
values: values
|
|
});
|
|
return true;
|
|
}
|
|
|
|
protected async createDatabaseTextBox(): Promise<azdata.FormComponent> {
|
|
this.databaseTextBox = this.view.modelBuilder.inputBox().withProperties({
|
|
required: true
|
|
}).component();
|
|
|
|
this.databaseTextBox.onTextChanged(async () => {
|
|
this.model.database = this.databaseTextBox.value;
|
|
});
|
|
|
|
return {
|
|
component: this.databaseTextBox,
|
|
title: localize('dacFx.databaseNameTextBox', 'Target Database')
|
|
};
|
|
}
|
|
|
|
protected async createDatabaseDropdown(): Promise<azdata.FormComponent> {
|
|
this.databaseDropdown = this.view.modelBuilder.dropDown().component();
|
|
|
|
// Handle database changes
|
|
this.databaseDropdown.onValueChanged(async () => {
|
|
this.model.database = (<azdata.CategoryValue>this.databaseDropdown.value).name;
|
|
this.fileTextBox.value = this.generateFilePathFromDatabaseAndTimestamp();
|
|
this.model.filePath = this.fileTextBox.value;
|
|
});
|
|
|
|
this.databaseLoader = this.view.modelBuilder.loadingComponent().withItem(this.databaseDropdown).withProperties({
|
|
required: true
|
|
}).component();
|
|
|
|
return {
|
|
component: this.databaseLoader,
|
|
title: localize('dacFx.sourceDatabaseDropdownTitle', 'Source Database')
|
|
};
|
|
}
|
|
|
|
protected async populateDatabaseDropdown(): Promise<boolean> {
|
|
this.databaseLoader.loading = true;
|
|
this.databaseDropdown.updateProperties({ values: [] });
|
|
|
|
if (!this.model.server) {
|
|
this.databaseLoader.loading = false;
|
|
return false;
|
|
}
|
|
|
|
let values = await this.getDatabaseValues();
|
|
|
|
// only update values and regenerate filepath if this is the first time and database isn't set yet
|
|
if (this.model.database !== values[0].name) {
|
|
this.model.database = values[0].name;
|
|
this.model.filePath = this.generateFilePathFromDatabaseAndTimestamp();
|
|
this.fileTextBox.value = this.model.filePath;
|
|
}
|
|
|
|
this.databaseDropdown.updateProperties({
|
|
values: values
|
|
});
|
|
this.databaseLoader.loading = false;
|
|
|
|
return true;
|
|
}
|
|
|
|
protected async createFileBrowserParts() {
|
|
this.fileTextBox = this.view.modelBuilder.inputBox().withProperties({
|
|
required: true
|
|
}).component();
|
|
|
|
this.fileButton = this.view.modelBuilder.button().withProperties({
|
|
label: '•••',
|
|
}).component();
|
|
}
|
|
|
|
protected generateFilePathFromDatabaseAndTimestamp(): string {
|
|
return this.model.database ? path.join(this.getRootPath(), sanitizeStringForFilename(this.model.database) + '-' + this.getDateTime() + this.fileExtension) : '';
|
|
}
|
|
|
|
protected getDateTime(): string {
|
|
let now = new Date();
|
|
return now.getFullYear() + '-' + (now.getMonth() + 1) + '-' + now.getDate() + '-' + now.getHours() + '-' + now.getMinutes();
|
|
}
|
|
|
|
protected getRootPath(): string {
|
|
// return rootpath of opened folder in file explorer if one is open, otherwise default to user home directory
|
|
return vscode.workspace.rootPath ? vscode.workspace.rootPath : os.homedir();
|
|
}
|
|
}
|
|
|
|
interface ConnectionDropdownValue extends azdata.CategoryValue {
|
|
connection: azdata.connection.Connection;
|
|
}
|
|
|