mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2025-12-21 01:41:31 +00:00
144 lines
5.7 KiB
TypeScript
144 lines
5.7 KiB
TypeScript
import * as ko from "knockout";
|
|
import Q from "q";
|
|
import * as ViewModels from "../../Contracts/ViewModels";
|
|
import * as Constants from "../../Common/Constants";
|
|
import { Action, ActionModifiers } from "../../Shared/Telemetry/TelemetryConstants";
|
|
import * as ErrorParserUtility from "../../Common/ErrorParserUtility";
|
|
import { CassandraAPIDataClient } from "../Tables/TableDataClient";
|
|
import { ConsoleDataType } from "../Menus/NotificationConsole/NotificationConsoleComponent";
|
|
import { ContextualPaneBase } from "./ContextualPaneBase";
|
|
import { DefaultExperienceUtility } from "../../Shared/DefaultExperienceUtility";
|
|
import DeleteFeedback from "../../Common/DeleteFeedback";
|
|
import { NotificationConsoleUtils } from "../../Utils/NotificationConsoleUtils";
|
|
import TelemetryProcessor from "../../Shared/Telemetry/TelemetryProcessor";
|
|
|
|
export default class DeleteCollectionConfirmationPane extends ContextualPaneBase
|
|
implements ViewModels.DeleteCollectionConfirmationPane {
|
|
public collectionIdConfirmationText: ko.Observable<string>;
|
|
public collectionIdConfirmation: ko.Observable<string>;
|
|
public containerDeleteFeedback: ko.Observable<string>;
|
|
public recordDeleteFeedback: ko.Observable<boolean>;
|
|
|
|
constructor(options: ViewModels.PaneOptions) {
|
|
super(options);
|
|
this.collectionIdConfirmationText = ko.observable<string>("Confirm by typing the collection id");
|
|
this.collectionIdConfirmation = ko.observable<string>();
|
|
this.containerDeleteFeedback = ko.observable<string>();
|
|
this.recordDeleteFeedback = ko.observable<boolean>(false);
|
|
this.title("Delete Collection");
|
|
this.resetData();
|
|
}
|
|
|
|
public submit(): Q.Promise<any> {
|
|
if (!this._isValid()) {
|
|
const selectedCollection: ViewModels.Collection = this.container.findSelectedCollection();
|
|
this.formErrors("Input collection name does not match the selected collection");
|
|
NotificationConsoleUtils.logConsoleMessage(
|
|
ConsoleDataType.Error,
|
|
`Error while deleting collection ${selectedCollection && selectedCollection.id()}: ${this.formErrors()}`
|
|
);
|
|
return Q.resolve();
|
|
}
|
|
|
|
this.formErrors("");
|
|
this.isExecuting(true);
|
|
const selectedCollection = <ViewModels.Collection>this.container.findSelectedCollection();
|
|
const startKey: number = TelemetryProcessor.traceStart(Action.DeleteCollection, {
|
|
databaseAccountName: this.container.databaseAccount().name,
|
|
defaultExperience: this.container.defaultExperience(),
|
|
collectionId: selectedCollection.id(),
|
|
dataExplorerArea: Constants.Areas.ContextualPane,
|
|
paneTitle: this.title()
|
|
});
|
|
let promise: Q.Promise<any>;
|
|
if (this.container.isPreferredApiCassandra()) {
|
|
promise = (<CassandraAPIDataClient>this.container.tableDataClient).deleteTableOrKeyspace(
|
|
this.container.databaseAccount().properties.cassandraEndpoint,
|
|
this.container.databaseAccount().id,
|
|
`DROP TABLE ${selectedCollection.databaseId}.${selectedCollection.id()};`,
|
|
this.container
|
|
);
|
|
} else {
|
|
promise = this.container.documentClientUtility.deleteCollection(selectedCollection);
|
|
}
|
|
return promise.then(
|
|
() => {
|
|
this.isExecuting(false);
|
|
this.close();
|
|
this.container.selectedNode(selectedCollection.database);
|
|
this.container.closeAllTabsForResource(selectedCollection.rid);
|
|
this.container.refreshAllDatabases();
|
|
this.resetData();
|
|
TelemetryProcessor.traceSuccess(
|
|
Action.DeleteCollection,
|
|
{
|
|
databaseAccountName: this.container.databaseAccount().name,
|
|
defaultExperience: this.container.defaultExperience(),
|
|
collectionId: selectedCollection.id(),
|
|
dataExplorerArea: Constants.Areas.ContextualPane,
|
|
paneTitle: this.title()
|
|
},
|
|
startKey
|
|
);
|
|
if (this.shouldRecordFeedback()) {
|
|
let deleteFeedback = new DeleteFeedback(
|
|
this.container.databaseAccount().id,
|
|
this.container.databaseAccount().name,
|
|
DefaultExperienceUtility.getApiKindFromDefaultExperience(this.container.defaultExperience()),
|
|
this.containerDeleteFeedback()
|
|
);
|
|
|
|
TelemetryProcessor.trace(
|
|
Action.DeleteCollection,
|
|
ActionModifiers.Mark,
|
|
JSON.stringify(deleteFeedback, Object.getOwnPropertyNames(deleteFeedback))
|
|
);
|
|
|
|
this.containerDeleteFeedback("");
|
|
}
|
|
},
|
|
(reason: any) => {
|
|
this.isExecuting(false);
|
|
const message = ErrorParserUtility.parse(reason);
|
|
this.formErrors(message[0].message);
|
|
this.formErrorsDetails(message[0].message);
|
|
TelemetryProcessor.traceFailure(
|
|
Action.DeleteCollection,
|
|
{
|
|
databaseAccountName: this.container.databaseAccount().name,
|
|
defaultExperience: this.container.defaultExperience(),
|
|
collectionId: selectedCollection.id(),
|
|
dataExplorerArea: Constants.Areas.ContextualPane,
|
|
paneTitle: this.title()
|
|
},
|
|
startKey
|
|
);
|
|
}
|
|
);
|
|
}
|
|
|
|
public resetData() {
|
|
this.collectionIdConfirmation("");
|
|
super.resetData();
|
|
}
|
|
|
|
public open() {
|
|
this.recordDeleteFeedback(this.shouldRecordFeedback());
|
|
super.open();
|
|
}
|
|
|
|
public shouldRecordFeedback(): boolean {
|
|
return this.container.isLastCollection() && !this.container.isSelectedDatabaseShared();
|
|
}
|
|
|
|
private _isValid(): boolean {
|
|
const selectedCollection: ViewModels.Collection = this.container.findSelectedCollection();
|
|
|
|
if (!selectedCollection) {
|
|
return false;
|
|
}
|
|
|
|
return this.collectionIdConfirmation() === selectedCollection.id();
|
|
}
|
|
}
|