mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2026-01-01 15:22:08 +00:00
* Persist query multiple query texts * Save multiple query tab histories * Save and restore states for QueryTab and DocumentsTab for SQL and Mongo * Enable Collection Scale/Settings restore * Persist documents tab current filter * Fix DocumentsTab conflict resolve mistake * Remove unused variable * Fix e2e test * Fix e2e localStorage reference * Try clearing local storage via playwright page * Clear local storage after opening page * Move restore flag behind feature flag. Whitelist restorable tabs in for Fabric. Restore e2e tests. * Fix typo * Fix: avoid setting undefined for preferredSize for the <Allotment.Pane> * Add comments * Move restore tabs after knockout configure step from Explorer constructor (which could be called multiple times)
74 lines
2.6 KiB
TypeScript
74 lines
2.6 KiB
TypeScript
import { ActionType, TabKind } from "Contracts/ActionContracts";
|
|
import React from "react";
|
|
import MongoUtility from "../../../Common/MongoUtility";
|
|
import * as ViewModels from "../../../Contracts/ViewModels";
|
|
import Explorer from "../../Explorer";
|
|
import { NewQueryTab } from "../QueryTab/QueryTab";
|
|
import { IQueryTabComponentProps, ITabAccessor, QueryTabComponent } from "../QueryTab/QueryTabComponent";
|
|
|
|
export interface IMongoQueryTabProps {
|
|
container: Explorer;
|
|
viewModelcollection?: ViewModels.Collection;
|
|
}
|
|
|
|
export class NewMongoQueryTab extends NewQueryTab {
|
|
public collection: ViewModels.Collection;
|
|
public iMongoQueryTabComponentProps: IQueryTabComponentProps;
|
|
public queryText: string;
|
|
|
|
constructor(
|
|
options: ViewModels.QueryTabOptions,
|
|
private mongoQueryTabProps: IMongoQueryTabProps,
|
|
) {
|
|
super(options, mongoQueryTabProps);
|
|
this.queryText = options.queryText ?? "";
|
|
this.iMongoQueryTabComponentProps = {
|
|
collection: options.collection,
|
|
isExecutionError: this.isExecutionError(),
|
|
tabId: this.tabId,
|
|
tabsBaseInstance: this,
|
|
queryText: this.queryText,
|
|
partitionKey: this.partitionKey,
|
|
splitterDirection: options.splitterDirection,
|
|
queryViewSizePercent: options.queryViewSizePercent,
|
|
container: this.mongoQueryTabProps.container,
|
|
onTabAccessor: (instance: ITabAccessor): void => {
|
|
this.iTabAccessor = instance;
|
|
},
|
|
isPreferredApiMongoDB: true,
|
|
monacoEditorSetting: "plaintext",
|
|
viewModelcollection: this.mongoQueryTabProps.viewModelcollection,
|
|
onUpdatePersistedState: (state: {
|
|
queryText: string;
|
|
splitterDirection: string;
|
|
queryViewSizePercent: number;
|
|
}): void => {
|
|
this.persistedState = {
|
|
actionType: ActionType.OpenCollectionTab,
|
|
tabKind: TabKind.SQLQuery,
|
|
databaseResourceId: options.collection.databaseId,
|
|
collectionResourceId: options.collection.id(),
|
|
query: {
|
|
text: state.queryText,
|
|
},
|
|
splitterDirection: state.splitterDirection as "vertical" | "horizontal",
|
|
queryViewSizePercent: state.queryViewSizePercent,
|
|
};
|
|
if (this.triggerPersistState) {
|
|
this.triggerPersistState();
|
|
}
|
|
},
|
|
};
|
|
}
|
|
|
|
/** Renders a Javascript object to be displayed inside Monaco Editor */
|
|
//eslint-disable-next-line
|
|
public renderObjectForEditor(value: any, replacer: any, space: string | number): string {
|
|
return MongoUtility.tojson(value, undefined, false);
|
|
}
|
|
|
|
public render(): JSX.Element {
|
|
return <QueryTabComponent {...this.iMongoQueryTabComponentProps} />;
|
|
}
|
|
}
|