mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2025-10-13 23:38:45 +01:00
commit current refactoring changes
This commit is contained in:
parent
9f7783f3f9
commit
6270358d9c
8059
package-lock.json
generated
8059
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -5,18 +5,18 @@ import DiscardIcon from "../../../../images/discard.svg";
|
|||||||
import SaveIcon from "../../../../images/save-cosmos.svg";
|
import SaveIcon from "../../../../images/save-cosmos.svg";
|
||||||
import { AuthType } from "../../../AuthType";
|
import { AuthType } from "../../../AuthType";
|
||||||
import * as Constants from "../../../Common/Constants";
|
import * as Constants from "../../../Common/Constants";
|
||||||
|
import { getErrorMessage, getErrorStack } from "../../../Common/ErrorHandlingUtils";
|
||||||
import { getIndexTransformationProgress } from "../../../Common/dataAccess/getIndexTransformationProgress";
|
import { getIndexTransformationProgress } from "../../../Common/dataAccess/getIndexTransformationProgress";
|
||||||
import { readMongoDBCollectionThroughRP } from "../../../Common/dataAccess/readMongoDBCollection";
|
import { readMongoDBCollectionThroughRP } from "../../../Common/dataAccess/readMongoDBCollection";
|
||||||
import { updateCollection } from "../../../Common/dataAccess/updateCollection";
|
import { updateCollection } from "../../../Common/dataAccess/updateCollection";
|
||||||
import { updateOffer } from "../../../Common/dataAccess/updateOffer";
|
import { updateOffer } from "../../../Common/dataAccess/updateOffer";
|
||||||
import { getErrorMessage, getErrorStack } from "../../../Common/ErrorHandlingUtils";
|
|
||||||
import * as DataModels from "../../../Contracts/DataModels";
|
import * as DataModels from "../../../Contracts/DataModels";
|
||||||
import * as ViewModels from "../../../Contracts/ViewModels";
|
import * as ViewModels from "../../../Contracts/ViewModels";
|
||||||
import { Action, ActionModifiers } from "../../../Shared/Telemetry/TelemetryConstants";
|
import { Action, ActionModifiers } from "../../../Shared/Telemetry/TelemetryConstants";
|
||||||
import { trace, traceFailure, traceStart, traceSuccess } from "../../../Shared/Telemetry/TelemetryProcessor";
|
import { trace, traceFailure, traceStart, traceSuccess } from "../../../Shared/Telemetry/TelemetryProcessor";
|
||||||
import { userContext } from "../../../UserContext";
|
import { userContext } from "../../../UserContext";
|
||||||
import { MongoDBCollectionResource, MongoIndex } from "../../../Utils/arm/generatedClients/cosmos/types";
|
|
||||||
import * as AutoPilotUtils from "../../../Utils/AutoPilotUtils";
|
import * as AutoPilotUtils from "../../../Utils/AutoPilotUtils";
|
||||||
|
import { MongoDBCollectionResource, MongoIndex } from "../../../Utils/arm/generatedClients/cosmos/types";
|
||||||
import { CommandButtonComponentProps } from "../../Controls/CommandButton/CommandButtonComponent";
|
import { CommandButtonComponentProps } from "../../Controls/CommandButton/CommandButtonComponent";
|
||||||
import { useCommandBar } from "../../Menus/CommandBar/CommandBarComponentAdapter";
|
import { useCommandBar } from "../../Menus/CommandBar/CommandBarComponentAdapter";
|
||||||
import { SettingsTabV2 } from "../../Tabs/SettingsTabV2";
|
import { SettingsTabV2 } from "../../Tabs/SettingsTabV2";
|
||||||
@ -37,15 +37,15 @@ import {
|
|||||||
AddMongoIndexProps,
|
AddMongoIndexProps,
|
||||||
ChangeFeedPolicyState,
|
ChangeFeedPolicyState,
|
||||||
GeospatialConfigType,
|
GeospatialConfigType,
|
||||||
|
MongoIndexTypes,
|
||||||
|
SettingsV2TabTypes,
|
||||||
|
TtlType,
|
||||||
getMongoNotification,
|
getMongoNotification,
|
||||||
getTabTitle,
|
getTabTitle,
|
||||||
hasDatabaseSharedThroughput,
|
hasDatabaseSharedThroughput,
|
||||||
isDirty,
|
isDirty,
|
||||||
MongoIndexTypes,
|
|
||||||
parseConflictResolutionMode,
|
parseConflictResolutionMode,
|
||||||
parseConflictResolutionProcedure,
|
parseConflictResolutionProcedure,
|
||||||
SettingsV2TabTypes,
|
|
||||||
TtlType,
|
|
||||||
} from "./SettingsUtils";
|
} from "./SettingsUtils";
|
||||||
|
|
||||||
interface SettingsV2TabInfo {
|
interface SettingsV2TabInfo {
|
||||||
|
@ -4,16 +4,21 @@
|
|||||||
* and update any knockout observables passed from the parent.
|
* and update any knockout observables passed from the parent.
|
||||||
*/
|
*/
|
||||||
import { CommandBar as FluentCommandBar, ICommandBarItemProps } from "@fluentui/react";
|
import { CommandBar as FluentCommandBar, ICommandBarItemProps } from "@fluentui/react";
|
||||||
|
import { AuthType } from "AuthType";
|
||||||
import { useNotebook } from "Explorer/Notebook/useNotebook";
|
import { useNotebook } from "Explorer/Notebook/useNotebook";
|
||||||
import * as React from "react";
|
|
||||||
import { userContext } from "UserContext";
|
import { userContext } from "UserContext";
|
||||||
|
import * as React from "react";
|
||||||
import create, { UseStore } from "zustand";
|
import create, { UseStore } from "zustand";
|
||||||
import { ConnectionStatusType, StyleConstants } from "../../../Common/Constants";
|
import { ConnectionStatusType, StyleConstants } from "../../../Common/Constants";
|
||||||
import { CommandButtonComponentProps } from "../../Controls/CommandButton/CommandButtonComponent";
|
import { CommandButtonComponentProps } from "../../Controls/CommandButton/CommandButtonComponent";
|
||||||
import Explorer from "../../Explorer";
|
import Explorer from "../../Explorer";
|
||||||
import { useSelectedNode } from "../../useSelectedNode";
|
import { useSelectedNode } from "../../useSelectedNode";
|
||||||
import * as CommandBarComponentButtonFactory from "./CommandBarComponentButtonFactory";
|
|
||||||
import * as CommandBarUtil from "./CommandBarUtil";
|
import * as CommandBarUtil from "./CommandBarUtil";
|
||||||
|
import * as createContextCommandBarButtons from "./CommandButtonsFactories/createContextCommandBarButtons";
|
||||||
|
import * as createControlCommandBarButtons from "./CommandButtonsFactories/createControlCommandBarButtons";
|
||||||
|
import * as createPostgreButtons from "./CommandButtonsFactories/createPostgreButtons";
|
||||||
|
import * as createStaticCommandBarButtons from "./CommandButtonsFactories/createStaticCommandBarButtons";
|
||||||
|
import * as createStaticCommandBarButtonsForResourceToken from "./CommandButtonsFactories/createStaticCommandBarButtonsForResourceToken";
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
container: Explorer;
|
container: Explorer;
|
||||||
@ -35,7 +40,7 @@ export const CommandBar: React.FC<Props> = ({ container }: Props) => {
|
|||||||
const backgroundColor = StyleConstants.BaseLight;
|
const backgroundColor = StyleConstants.BaseLight;
|
||||||
|
|
||||||
if (userContext.apiType === "Postgres") {
|
if (userContext.apiType === "Postgres") {
|
||||||
const buttons = CommandBarComponentButtonFactory.createPostgreButtons(container);
|
const buttons = createPostgreButtons.createPostgreButtons(container);
|
||||||
return (
|
return (
|
||||||
<div className="commandBarContainer">
|
<div className="commandBarContainer">
|
||||||
<FluentCommandBar
|
<FluentCommandBar
|
||||||
@ -50,11 +55,18 @@ export const CommandBar: React.FC<Props> = ({ container }: Props) => {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const staticButtons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(container, selectedNodeState);
|
const staticButtons =
|
||||||
|
userContext.authType === AuthType.ResourceToken
|
||||||
|
? createStaticCommandBarButtonsForResourceToken.createStaticCommandBarButtonsForResourceToken(
|
||||||
|
container,
|
||||||
|
selectedNodeState
|
||||||
|
)
|
||||||
|
: createStaticCommandBarButtons.createStaticCommandBarButtons(container, selectedNodeState);
|
||||||
|
|
||||||
const contextButtons = (buttons || []).concat(
|
const contextButtons = (buttons || []).concat(
|
||||||
CommandBarComponentButtonFactory.createContextCommandBarButtons(container, selectedNodeState)
|
createContextCommandBarButtons.createContextCommandBarButtons(container, selectedNodeState)
|
||||||
);
|
);
|
||||||
const controlButtons = CommandBarComponentButtonFactory.createControlCommandBarButtons(container);
|
const controlButtons = createControlCommandBarButtons.createControlCommandBarButtons(container);
|
||||||
|
|
||||||
const uiFabricStaticButtons = CommandBarUtil.convertButton(staticButtons, backgroundColor);
|
const uiFabricStaticButtons = CommandBarUtil.convertButton(staticButtons, backgroundColor);
|
||||||
if (buttons && buttons.length > 0) {
|
if (buttons && buttons.length > 0) {
|
||||||
|
@ -9,7 +9,7 @@ import NotebookManager from "../../Notebook/NotebookManager";
|
|||||||
import { useNotebook } from "../../Notebook/useNotebook";
|
import { useNotebook } from "../../Notebook/useNotebook";
|
||||||
import { useDatabases } from "../../useDatabases";
|
import { useDatabases } from "../../useDatabases";
|
||||||
import { useSelectedNode } from "../../useSelectedNode";
|
import { useSelectedNode } from "../../useSelectedNode";
|
||||||
import * as CommandBarComponentButtonFactory from "./CommandBarComponentButtonFactory";
|
import * as createStaticCommandBarButtons from "./CommandButtonsFactories/createStaticCommandBarButtons";
|
||||||
|
|
||||||
describe("CommandBarComponentButtonFactory tests", () => {
|
describe("CommandBarComponentButtonFactory tests", () => {
|
||||||
let mockExplorer: Explorer;
|
let mockExplorer: Explorer;
|
||||||
@ -32,7 +32,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("Button should be visible", () => {
|
it("Button should be visible", () => {
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const enableAzureSynapseLinkBtn = buttons.find(
|
const enableAzureSynapseLinkBtn = buttons.find(
|
||||||
(button) => button.commandButtonLabel === enableAzureSynapseLinkBtnLabel
|
(button) => button.commandButtonLabel === enableAzureSynapseLinkBtnLabel
|
||||||
);
|
);
|
||||||
@ -48,7 +48,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
} as DatabaseAccount,
|
} as DatabaseAccount,
|
||||||
});
|
});
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const enableAzureSynapseLinkBtn = buttons.find(
|
const enableAzureSynapseLinkBtn = buttons.find(
|
||||||
(button) => button.commandButtonLabel === enableAzureSynapseLinkBtnLabel
|
(button) => button.commandButtonLabel === enableAzureSynapseLinkBtnLabel
|
||||||
);
|
);
|
||||||
@ -64,7 +64,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
} as DatabaseAccount,
|
} as DatabaseAccount,
|
||||||
});
|
});
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const enableAzureSynapseLinkBtn = buttons.find(
|
const enableAzureSynapseLinkBtn = buttons.find(
|
||||||
(button) => button.commandButtonLabel === enableAzureSynapseLinkBtnLabel
|
(button) => button.commandButtonLabel === enableAzureSynapseLinkBtnLabel
|
||||||
);
|
);
|
||||||
@ -100,7 +100,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
useNotebook.getState().setIsNotebookEnabled(true);
|
useNotebook.getState().setIsNotebookEnabled(true);
|
||||||
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const enableNotebookBtn = buttons.find((button) => button.commandButtonLabel === enableNotebookBtnLabel);
|
const enableNotebookBtn = buttons.find((button) => button.commandButtonLabel === enableNotebookBtnLabel);
|
||||||
expect(enableNotebookBtn).toBeUndefined();
|
expect(enableNotebookBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
@ -110,7 +110,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
portalEnv: "mooncake",
|
portalEnv: "mooncake",
|
||||||
});
|
});
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const enableNotebookBtn = buttons.find((button) => button.commandButtonLabel === enableNotebookBtnLabel);
|
const enableNotebookBtn = buttons.find((button) => button.commandButtonLabel === enableNotebookBtnLabel);
|
||||||
expect(enableNotebookBtn).toBeUndefined();
|
expect(enableNotebookBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
@ -118,7 +118,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
it("Notebooks is not enabled but is available - button should be shown and enabled", () => {
|
it("Notebooks is not enabled but is available - button should be shown and enabled", () => {
|
||||||
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const enableNotebookBtn = buttons.find((button) => button.commandButtonLabel === enableNotebookBtnLabel);
|
const enableNotebookBtn = buttons.find((button) => button.commandButtonLabel === enableNotebookBtnLabel);
|
||||||
|
|
||||||
//TODO: modify once notebooks are available
|
//TODO: modify once notebooks are available
|
||||||
@ -129,7 +129,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("Notebooks is not enabled and is unavailable - button should be shown and disabled", () => {
|
it("Notebooks is not enabled and is unavailable - button should be shown and disabled", () => {
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const enableNotebookBtn = buttons.find((button) => button.commandButtonLabel === enableNotebookBtnLabel);
|
const enableNotebookBtn = buttons.find((button) => button.commandButtonLabel === enableNotebookBtnLabel);
|
||||||
|
|
||||||
//TODO: modify once notebooks are available
|
//TODO: modify once notebooks are available
|
||||||
@ -180,7 +180,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
updateUserContext({
|
updateUserContext({
|
||||||
apiType: "SQL",
|
apiType: "SQL",
|
||||||
});
|
});
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
||||||
expect(openMongoShellBtn).toBeUndefined();
|
expect(openMongoShellBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
@ -190,13 +190,13 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
portalEnv: "mooncake",
|
portalEnv: "mooncake",
|
||||||
});
|
});
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
||||||
expect(openMongoShellBtn).toBeUndefined();
|
expect(openMongoShellBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Notebooks is not enabled and is unavailable - button should be hidden", () => {
|
it("Notebooks is not enabled and is unavailable - button should be hidden", () => {
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
||||||
expect(openMongoShellBtn).toBeUndefined();
|
expect(openMongoShellBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
@ -204,7 +204,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
it("Notebooks is not enabled and is available - button should be hidden", () => {
|
it("Notebooks is not enabled and is available - button should be hidden", () => {
|
||||||
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
||||||
expect(openMongoShellBtn).toBeUndefined();
|
expect(openMongoShellBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
@ -212,7 +212,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
it("Notebooks is enabled and is unavailable - button should be shown and enabled", () => {
|
it("Notebooks is enabled and is unavailable - button should be shown and enabled", () => {
|
||||||
useNotebook.getState().setIsNotebookEnabled(true);
|
useNotebook.getState().setIsNotebookEnabled(true);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
||||||
expect(openMongoShellBtn).toBeDefined();
|
expect(openMongoShellBtn).toBeDefined();
|
||||||
|
|
||||||
@ -226,7 +226,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
useNotebook.getState().setIsNotebookEnabled(true);
|
useNotebook.getState().setIsNotebookEnabled(true);
|
||||||
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
||||||
expect(openMongoShellBtn).toBeDefined();
|
expect(openMongoShellBtn).toBeDefined();
|
||||||
|
|
||||||
@ -241,7 +241,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
||||||
useNotebook.getState().setIsShellEnabled(false);
|
useNotebook.getState().setIsShellEnabled(false);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
const openMongoShellBtn = buttons.find((button) => button.commandButtonLabel === openMongoShellBtnLabel);
|
||||||
expect(openMongoShellBtn).toBeUndefined();
|
expect(openMongoShellBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
@ -285,7 +285,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
},
|
},
|
||||||
} as DatabaseAccount,
|
} as DatabaseAccount,
|
||||||
});
|
});
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
||||||
expect(openCassandraShellBtn).toBeUndefined();
|
expect(openCassandraShellBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
@ -295,13 +295,13 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
portalEnv: "mooncake",
|
portalEnv: "mooncake",
|
||||||
});
|
});
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
||||||
expect(openCassandraShellBtn).toBeUndefined();
|
expect(openCassandraShellBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Notebooks is not enabled and is unavailable - button should be shown and disabled", () => {
|
it("Notebooks is not enabled and is unavailable - button should be shown and disabled", () => {
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
||||||
expect(openCassandraShellBtn).toBeUndefined();
|
expect(openCassandraShellBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
@ -309,7 +309,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
it("Notebooks is not enabled and is available - button should be shown and enabled", () => {
|
it("Notebooks is not enabled and is available - button should be shown and enabled", () => {
|
||||||
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
||||||
expect(openCassandraShellBtn).toBeUndefined();
|
expect(openCassandraShellBtn).toBeUndefined();
|
||||||
});
|
});
|
||||||
@ -317,7 +317,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
it("Notebooks is enabled and is unavailable - button should be shown and enabled", () => {
|
it("Notebooks is enabled and is unavailable - button should be shown and enabled", () => {
|
||||||
useNotebook.getState().setIsNotebookEnabled(true);
|
useNotebook.getState().setIsNotebookEnabled(true);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
||||||
|
|
||||||
expect(openCassandraShellBtn).toBeDefined();
|
expect(openCassandraShellBtn).toBeDefined();
|
||||||
@ -332,7 +332,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
useNotebook.getState().setIsNotebookEnabled(true);
|
useNotebook.getState().setIsNotebookEnabled(true);
|
||||||
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
useNotebook.getState().setIsNotebooksEnabledForAccount(true);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
const openCassandraShellBtn = buttons.find((button) => button.commandButtonLabel === openCassandraShellBtnLabel);
|
||||||
expect(openCassandraShellBtn).toBeDefined();
|
expect(openCassandraShellBtn).toBeDefined();
|
||||||
|
|
||||||
@ -370,7 +370,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
it("Notebooks is enabled and GitHubOAuthService is not logged in - connect to github button should be visible", () => {
|
it("Notebooks is enabled and GitHubOAuthService is not logged in - connect to github button should be visible", () => {
|
||||||
useNotebook.getState().setIsNotebookEnabled(true);
|
useNotebook.getState().setIsNotebookEnabled(true);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const connectToGitHubBtn = buttons.find((button) => button.commandButtonLabel === connectToGitHubBtnLabel);
|
const connectToGitHubBtn = buttons.find((button) => button.commandButtonLabel === connectToGitHubBtnLabel);
|
||||||
expect(connectToGitHubBtn).toBeDefined();
|
expect(connectToGitHubBtn).toBeDefined();
|
||||||
});
|
});
|
||||||
@ -379,7 +379,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
useNotebook.getState().setIsNotebookEnabled(true);
|
useNotebook.getState().setIsNotebookEnabled(true);
|
||||||
mockExplorer.notebookManager.gitHubOAuthService.isLoggedIn = jest.fn().mockReturnValue(true);
|
mockExplorer.notebookManager.gitHubOAuthService.isLoggedIn = jest.fn().mockReturnValue(true);
|
||||||
|
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
const manageGitHubSettingsBtn = buttons.find(
|
const manageGitHubSettingsBtn = buttons.find(
|
||||||
(button) => button.commandButtonLabel === manageGitHubSettingsBtnLabel
|
(button) => button.commandButtonLabel === manageGitHubSettingsBtnLabel
|
||||||
);
|
);
|
||||||
@ -387,7 +387,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("Notebooks is not enabled - connect to github and manage github settings buttons should be hidden", () => {
|
it("Notebooks is not enabled - connect to github and manage github settings buttons should be hidden", () => {
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
|
|
||||||
const connectToGitHubBtn = buttons.find((button) => button.commandButtonLabel === connectToGitHubBtnLabel);
|
const connectToGitHubBtn = buttons.find((button) => button.commandButtonLabel === connectToGitHubBtnLabel);
|
||||||
expect(connectToGitHubBtn).toBeUndefined();
|
expect(connectToGitHubBtn).toBeUndefined();
|
||||||
@ -419,7 +419,7 @@ describe("CommandBarComponentButtonFactory tests", () => {
|
|||||||
kind: "DocumentDB",
|
kind: "DocumentDB",
|
||||||
} as DatabaseAccount,
|
} as DatabaseAccount,
|
||||||
});
|
});
|
||||||
const buttons = CommandBarComponentButtonFactory.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
const buttons = createStaticCommandBarButtons.createStaticCommandBarButtons(mockExplorer, selectedNodeState);
|
||||||
expect(buttons.length).toBe(2);
|
expect(buttons.length).toBe(2);
|
||||||
expect(buttons[0].commandButtonLabel).toBe("New SQL Query");
|
expect(buttons[0].commandButtonLabel).toBe("New SQL Query");
|
||||||
expect(buttons[0].disabled).toBe(false);
|
expect(buttons[0].disabled).toBe(false);
|
||||||
|
@ -1,636 +0,0 @@
|
|||||||
import { Action } from "Shared/Telemetry/TelemetryConstants";
|
|
||||||
import { traceOpen } from "Shared/Telemetry/TelemetryProcessor";
|
|
||||||
import { ReactTabKind, useTabs } from "hooks/useTabs";
|
|
||||||
import * as React from "react";
|
|
||||||
import AddCollectionIcon from "../../../../images/AddCollection.svg";
|
|
||||||
import AddDatabaseIcon from "../../../../images/AddDatabase.svg";
|
|
||||||
import AddSqlQueryIcon from "../../../../images/AddSqlQuery_16x16.svg";
|
|
||||||
import AddStoredProcedureIcon from "../../../../images/AddStoredProcedure.svg";
|
|
||||||
import AddTriggerIcon from "../../../../images/AddTrigger.svg";
|
|
||||||
import AddUdfIcon from "../../../../images/AddUdf.svg";
|
|
||||||
import BrowseQueriesIcon from "../../../../images/BrowseQuery.svg";
|
|
||||||
import CosmosTerminalIcon from "../../../../images/Cosmos-Terminal.svg";
|
|
||||||
import FeedbackIcon from "../../../../images/Feedback-Command.svg";
|
|
||||||
import HostedTerminalIcon from "../../../../images/Hosted-Terminal.svg";
|
|
||||||
import OpenQueryFromDiskIcon from "../../../../images/OpenQueryFromDisk.svg";
|
|
||||||
import GitHubIcon from "../../../../images/github.svg";
|
|
||||||
import NewNotebookIcon from "../../../../images/notebook/Notebook-new.svg";
|
|
||||||
import ResetWorkspaceIcon from "../../../../images/notebook/Notebook-reset-workspace.svg";
|
|
||||||
import OpenInTabIcon from "../../../../images/open-in-tab.svg";
|
|
||||||
import SettingsIcon from "../../../../images/settings_15x15.svg";
|
|
||||||
import SynapseIcon from "../../../../images/synapse-link.svg";
|
|
||||||
import { AuthType } from "../../../AuthType";
|
|
||||||
import * as Constants from "../../../Common/Constants";
|
|
||||||
import { Platform, configContext } from "../../../ConfigContext";
|
|
||||||
import * as ViewModels from "../../../Contracts/ViewModels";
|
|
||||||
import { JunoClient } from "../../../Juno/JunoClient";
|
|
||||||
import { userContext } from "../../../UserContext";
|
|
||||||
import { getCollectionName, getDatabaseName } from "../../../Utils/APITypeUtils";
|
|
||||||
import { isRunningOnNationalCloud } from "../../../Utils/CloudUtils";
|
|
||||||
import { useSidePanel } from "../../../hooks/useSidePanel";
|
|
||||||
import { CommandButtonComponentProps } from "../../Controls/CommandButton/CommandButtonComponent";
|
|
||||||
import Explorer from "../../Explorer";
|
|
||||||
import { useNotebook } from "../../Notebook/useNotebook";
|
|
||||||
import { OpenFullScreen } from "../../OpenFullScreen";
|
|
||||||
import { AddDatabasePanel } from "../../Panes/AddDatabasePanel/AddDatabasePanel";
|
|
||||||
import { BrowseQueriesPane } from "../../Panes/BrowseQueriesPane/BrowseQueriesPane";
|
|
||||||
import { GitHubReposPanel } from "../../Panes/GitHubReposPanel/GitHubReposPanel";
|
|
||||||
import { LoadQueryPane } from "../../Panes/LoadQueryPane/LoadQueryPane";
|
|
||||||
import { SettingsPane } from "../../Panes/SettingsPane/SettingsPane";
|
|
||||||
import { useDatabases } from "../../useDatabases";
|
|
||||||
import { SelectedNodeState, useSelectedNode } from "../../useSelectedNode";
|
|
||||||
|
|
||||||
let counter = 0;
|
|
||||||
|
|
||||||
export function createStaticCommandBarButtons(
|
|
||||||
container: Explorer,
|
|
||||||
selectedNodeState: SelectedNodeState
|
|
||||||
): CommandButtonComponentProps[] {
|
|
||||||
if (userContext.authType === AuthType.ResourceToken) {
|
|
||||||
return createStaticCommandBarButtonsForResourceToken(container, selectedNodeState);
|
|
||||||
}
|
|
||||||
|
|
||||||
const newCollectionBtn = createNewCollectionGroup(container);
|
|
||||||
const buttons: CommandButtonComponentProps[] = [];
|
|
||||||
|
|
||||||
buttons.push(newCollectionBtn);
|
|
||||||
if (userContext.apiType !== "Tables" && userContext.apiType !== "Cassandra") {
|
|
||||||
const addSynapseLink = createOpenSynapseLinkDialogButton(container);
|
|
||||||
|
|
||||||
if (addSynapseLink) {
|
|
||||||
buttons.push(createDivider());
|
|
||||||
buttons.push(addSynapseLink);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (userContext.apiType !== "Tables") {
|
|
||||||
newCollectionBtn.children = [createNewCollectionGroup(container)];
|
|
||||||
const newDatabaseBtn = createNewDatabase(container);
|
|
||||||
newCollectionBtn.children.push(newDatabaseBtn);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (useNotebook.getState().isNotebookEnabled) {
|
|
||||||
buttons.push(createDivider());
|
|
||||||
const notebookButtons: CommandButtonComponentProps[] = [];
|
|
||||||
|
|
||||||
const newNotebookButton = createNewNotebookButton(container);
|
|
||||||
newNotebookButton.children = [createNewNotebookButton(container), createuploadNotebookButton(container)];
|
|
||||||
notebookButtons.push(newNotebookButton);
|
|
||||||
|
|
||||||
if (container.notebookManager?.gitHubOAuthService) {
|
|
||||||
notebookButtons.push(createManageGitHubAccountButton(container));
|
|
||||||
}
|
|
||||||
if (useNotebook.getState().isPhoenixFeatures && configContext.isTerminalEnabled) {
|
|
||||||
notebookButtons.push(createOpenTerminalButton(container));
|
|
||||||
}
|
|
||||||
if (useNotebook.getState().isPhoenixNotebooks && selectedNodeState.isConnectedToContainer()) {
|
|
||||||
notebookButtons.push(createNotebookWorkspaceResetButton(container));
|
|
||||||
}
|
|
||||||
if (
|
|
||||||
(userContext.apiType === "Mongo" &&
|
|
||||||
useNotebook.getState().isShellEnabled &&
|
|
||||||
selectedNodeState.isDatabaseNodeOrNoneSelected()) ||
|
|
||||||
userContext.apiType === "Cassandra"
|
|
||||||
) {
|
|
||||||
notebookButtons.push(createDivider());
|
|
||||||
if (userContext.apiType === "Cassandra") {
|
|
||||||
notebookButtons.push(createOpenCassandraTerminalButton(container));
|
|
||||||
} else {
|
|
||||||
notebookButtons.push(createOpenMongoTerminalButton(container));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
notebookButtons.forEach((btn) => {
|
|
||||||
if (btn.commandButtonLabel.indexOf("Cassandra") !== -1) {
|
|
||||||
if (!useNotebook.getState().isPhoenixFeatures) {
|
|
||||||
applyNotebooksTemporarilyDownStyle(btn, Constants.Notebook.cassandraShellTemporarilyDownMsg);
|
|
||||||
}
|
|
||||||
} else if (btn.commandButtonLabel.indexOf("Mongo") !== -1) {
|
|
||||||
if (!useNotebook.getState().isPhoenixFeatures) {
|
|
||||||
applyNotebooksTemporarilyDownStyle(btn, Constants.Notebook.mongoShellTemporarilyDownMsg);
|
|
||||||
}
|
|
||||||
} else if (btn.commandButtonLabel.indexOf("Open Terminal") !== -1) {
|
|
||||||
if (!useNotebook.getState().isPhoenixFeatures) {
|
|
||||||
applyNotebooksTemporarilyDownStyle(btn, Constants.Notebook.temporarilyDownMsg);
|
|
||||||
}
|
|
||||||
} else if (!useNotebook.getState().isPhoenixNotebooks) {
|
|
||||||
applyNotebooksTemporarilyDownStyle(btn, Constants.Notebook.temporarilyDownMsg);
|
|
||||||
}
|
|
||||||
buttons.push(btn);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!selectedNodeState.isDatabaseNodeOrNoneSelected()) {
|
|
||||||
const isQuerySupported = userContext.apiType === "SQL" || userContext.apiType === "Gremlin";
|
|
||||||
|
|
||||||
if (isQuerySupported) {
|
|
||||||
buttons.push(createDivider());
|
|
||||||
const newSqlQueryBtn = createNewSQLQueryButton(selectedNodeState);
|
|
||||||
buttons.push(newSqlQueryBtn);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isQuerySupported && selectedNodeState.findSelectedCollection()) {
|
|
||||||
const openQueryBtn = createOpenQueryButton(container);
|
|
||||||
openQueryBtn.children = [createOpenQueryButton(container), createOpenQueryFromDiskButton()];
|
|
||||||
buttons.push(openQueryBtn);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (areScriptsSupported()) {
|
|
||||||
const label = "New Stored Procedure";
|
|
||||||
const newStoredProcedureBtn: CommandButtonComponentProps = {
|
|
||||||
iconSrc: AddStoredProcedureIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
|
||||||
selectedCollection && selectedCollection.onNewStoredProcedureClick(selectedCollection);
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
disabled:
|
|
||||||
useSelectedNode.getState().isQueryCopilotCollectionSelected() ||
|
|
||||||
selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
|
||||||
};
|
|
||||||
|
|
||||||
newStoredProcedureBtn.children = createScriptCommandButtons(selectedNodeState);
|
|
||||||
buttons.push(newStoredProcedureBtn);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return buttons;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function createContextCommandBarButtons(
|
|
||||||
container: Explorer,
|
|
||||||
selectedNodeState: SelectedNodeState
|
|
||||||
): CommandButtonComponentProps[] {
|
|
||||||
const buttons: CommandButtonComponentProps[] = [];
|
|
||||||
|
|
||||||
if (!selectedNodeState.isDatabaseNodeOrNoneSelected() && userContext.apiType === "Mongo") {
|
|
||||||
const label = useNotebook.getState().isShellEnabled ? "Open Mongo Shell" : "New Shell";
|
|
||||||
const newMongoShellBtn: CommandButtonComponentProps = {
|
|
||||||
iconSrc: HostedTerminalIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
|
||||||
if (useNotebook.getState().isShellEnabled) {
|
|
||||||
container.openNotebookTerminal(ViewModels.TerminalKind.Mongo);
|
|
||||||
} else {
|
|
||||||
selectedCollection && selectedCollection.onNewMongoShellClick();
|
|
||||||
}
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
};
|
|
||||||
buttons.push(newMongoShellBtn);
|
|
||||||
}
|
|
||||||
|
|
||||||
return buttons;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function createControlCommandBarButtons(container: Explorer): CommandButtonComponentProps[] {
|
|
||||||
const buttons: CommandButtonComponentProps[] = [
|
|
||||||
{
|
|
||||||
iconSrc: SettingsIcon,
|
|
||||||
iconAlt: "Settings",
|
|
||||||
onCommandClick: () => useSidePanel.getState().openSidePanel("Settings", <SettingsPane />),
|
|
||||||
commandButtonLabel: undefined,
|
|
||||||
ariaLabel: "Settings",
|
|
||||||
tooltipText: "Settings",
|
|
||||||
hasPopup: true,
|
|
||||||
disabled: false,
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|
||||||
const showOpenFullScreen =
|
|
||||||
configContext.platform === Platform.Portal && !isRunningOnNationalCloud() && userContext.apiType !== "Gremlin";
|
|
||||||
|
|
||||||
if (showOpenFullScreen) {
|
|
||||||
const label = "Open Full Screen";
|
|
||||||
const fullScreenButton: CommandButtonComponentProps = {
|
|
||||||
id: "openFullScreenBtn",
|
|
||||||
iconSrc: OpenInTabIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
useSidePanel.getState().openSidePanel("Open Full Screen", <OpenFullScreen />);
|
|
||||||
},
|
|
||||||
commandButtonLabel: undefined,
|
|
||||||
ariaLabel: label,
|
|
||||||
tooltipText: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled: !showOpenFullScreen,
|
|
||||||
className: "OpenFullScreen",
|
|
||||||
};
|
|
||||||
buttons.push(fullScreenButton);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (configContext.platform !== Platform.Emulator) {
|
|
||||||
const label = "Feedback";
|
|
||||||
const feedbackButtonOptions: CommandButtonComponentProps = {
|
|
||||||
iconSrc: FeedbackIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => container.provideFeedbackEmail(),
|
|
||||||
commandButtonLabel: undefined,
|
|
||||||
ariaLabel: label,
|
|
||||||
tooltipText: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled: false,
|
|
||||||
};
|
|
||||||
buttons.push(feedbackButtonOptions);
|
|
||||||
}
|
|
||||||
|
|
||||||
return buttons;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function createDivider(): CommandButtonComponentProps {
|
|
||||||
const label = `divider${counter++}`;
|
|
||||||
return {
|
|
||||||
isDivider: true,
|
|
||||||
commandButtonLabel: label,
|
|
||||||
hasPopup: false,
|
|
||||||
iconSrc: undefined,
|
|
||||||
iconAlt: undefined,
|
|
||||||
onCommandClick: undefined,
|
|
||||||
ariaLabel: label,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function areScriptsSupported(): boolean {
|
|
||||||
return userContext.apiType === "SQL" || userContext.apiType === "Gremlin";
|
|
||||||
}
|
|
||||||
|
|
||||||
function createNewCollectionGroup(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const label = `New ${getCollectionName()}`;
|
|
||||||
return {
|
|
||||||
iconSrc: AddCollectionIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => container.onNewCollectionClicked(),
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
id: "createNewContainerCommandButton",
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createOpenSynapseLinkDialogButton(container: Explorer): CommandButtonComponentProps {
|
|
||||||
if (configContext.platform === Platform.Emulator) {
|
|
||||||
return undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (userContext?.databaseAccount?.properties?.enableAnalyticalStorage) {
|
|
||||||
return undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
const capabilities = userContext?.databaseAccount?.properties?.capabilities || [];
|
|
||||||
if (capabilities.some((capability) => capability.name === Constants.CapabilityNames.EnableStorageAnalytics)) {
|
|
||||||
return undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
const label = "Enable Azure Synapse Link";
|
|
||||||
return {
|
|
||||||
iconSrc: SynapseIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => container.openEnableSynapseLinkDialog(),
|
|
||||||
commandButtonLabel: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled:
|
|
||||||
useSelectedNode.getState().isQueryCopilotCollectionSelected() || useNotebook.getState().isSynapseLinkUpdating,
|
|
||||||
ariaLabel: label,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createNewDatabase(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const label = "New " + getDatabaseName();
|
|
||||||
return {
|
|
||||||
iconSrc: AddDatabaseIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: async () => {
|
|
||||||
const throughputCap = userContext.databaseAccount?.properties.capacity?.totalThroughputLimit;
|
|
||||||
if (throughputCap && throughputCap !== -1) {
|
|
||||||
await useDatabases.getState().loadAllOffers();
|
|
||||||
}
|
|
||||||
useSidePanel.getState().openSidePanel("New " + getDatabaseName(), <AddDatabasePanel explorer={container} />);
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createNewSQLQueryButton(selectedNodeState: SelectedNodeState): CommandButtonComponentProps {
|
|
||||||
if (userContext.apiType === "SQL" || userContext.apiType === "Gremlin") {
|
|
||||||
const label = "New SQL Query";
|
|
||||||
return {
|
|
||||||
id: "newQueryBtn",
|
|
||||||
iconSrc: AddSqlQueryIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
if (useSelectedNode.getState().isQueryCopilotCollectionSelected()) {
|
|
||||||
useTabs.getState().openAndActivateReactTab(ReactTabKind.QueryCopilot);
|
|
||||||
traceOpen(Action.OpenQueryCopilotFromNewQuery, { apiType: userContext.apiType });
|
|
||||||
} else {
|
|
||||||
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
|
||||||
selectedCollection && selectedCollection.onNewQueryClick(selectedCollection);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
disabled: selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
|
||||||
};
|
|
||||||
} else if (userContext.apiType === "Mongo") {
|
|
||||||
const label = "New Query";
|
|
||||||
return {
|
|
||||||
id: "newQueryBtn",
|
|
||||||
iconSrc: AddSqlQueryIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
|
||||||
selectedCollection && selectedCollection.onNewMongoQueryClick(selectedCollection);
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
disabled: selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
return undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function createScriptCommandButtons(selectedNodeState: SelectedNodeState): CommandButtonComponentProps[] {
|
|
||||||
const buttons: CommandButtonComponentProps[] = [];
|
|
||||||
|
|
||||||
const shouldEnableScriptsCommands: boolean =
|
|
||||||
!selectedNodeState.isDatabaseNodeOrNoneSelected() && areScriptsSupported();
|
|
||||||
|
|
||||||
if (shouldEnableScriptsCommands) {
|
|
||||||
const label = "New Stored Procedure";
|
|
||||||
const newStoredProcedureBtn: CommandButtonComponentProps = {
|
|
||||||
iconSrc: AddStoredProcedureIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
|
||||||
selectedCollection && selectedCollection.onNewStoredProcedureClick(selectedCollection);
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
disabled:
|
|
||||||
useSelectedNode.getState().isQueryCopilotCollectionSelected() ||
|
|
||||||
selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
|
||||||
};
|
|
||||||
buttons.push(newStoredProcedureBtn);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (shouldEnableScriptsCommands) {
|
|
||||||
const label = "New UDF";
|
|
||||||
const newUserDefinedFunctionBtn: CommandButtonComponentProps = {
|
|
||||||
iconSrc: AddUdfIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
|
||||||
selectedCollection && selectedCollection.onNewUserDefinedFunctionClick(selectedCollection);
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
disabled:
|
|
||||||
useSelectedNode.getState().isQueryCopilotCollectionSelected() ||
|
|
||||||
selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
|
||||||
};
|
|
||||||
buttons.push(newUserDefinedFunctionBtn);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (shouldEnableScriptsCommands) {
|
|
||||||
const label = "New Trigger";
|
|
||||||
const newTriggerBtn: CommandButtonComponentProps = {
|
|
||||||
iconSrc: AddTriggerIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
|
||||||
selectedCollection && selectedCollection.onNewTriggerClick(selectedCollection);
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
disabled:
|
|
||||||
useSelectedNode.getState().isQueryCopilotCollectionSelected() ||
|
|
||||||
selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
|
||||||
};
|
|
||||||
buttons.push(newTriggerBtn);
|
|
||||||
}
|
|
||||||
|
|
||||||
return buttons;
|
|
||||||
}
|
|
||||||
|
|
||||||
function applyNotebooksTemporarilyDownStyle(buttonProps: CommandButtonComponentProps, tooltip: string): void {
|
|
||||||
if (!buttonProps.isDivider) {
|
|
||||||
buttonProps.disabled = true;
|
|
||||||
buttonProps.tooltipText = tooltip;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function createNewNotebookButton(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const label = "New Notebook";
|
|
||||||
return {
|
|
||||||
id: "newNotebookBtn",
|
|
||||||
iconSrc: NewNotebookIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => container.onNewNotebookClicked(),
|
|
||||||
commandButtonLabel: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
|
||||||
ariaLabel: label,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createuploadNotebookButton(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const label = "Upload to Notebook Server";
|
|
||||||
return {
|
|
||||||
iconSrc: NewNotebookIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => container.openUploadFilePanel(),
|
|
||||||
commandButtonLabel: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
|
||||||
ariaLabel: label,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createOpenQueryButton(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const label = "Open Query";
|
|
||||||
return {
|
|
||||||
iconSrc: BrowseQueriesIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () =>
|
|
||||||
useSidePanel.getState().openSidePanel("Open Saved Queries", <BrowseQueriesPane explorer={container} />),
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createOpenQueryFromDiskButton(): CommandButtonComponentProps {
|
|
||||||
const label = "Open Query From Disk";
|
|
||||||
return {
|
|
||||||
iconSrc: OpenQueryFromDiskIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => useSidePanel.getState().openSidePanel("Load Query", <LoadQueryPane />),
|
|
||||||
commandButtonLabel: label,
|
|
||||||
ariaLabel: label,
|
|
||||||
hasPopup: true,
|
|
||||||
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createOpenTerminalButton(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const label = "Open Terminal";
|
|
||||||
return {
|
|
||||||
iconSrc: CosmosTerminalIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => container.openNotebookTerminal(ViewModels.TerminalKind.Default),
|
|
||||||
commandButtonLabel: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
|
||||||
ariaLabel: label,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createOpenMongoTerminalButton(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const label = "Open Mongo Shell";
|
|
||||||
const tooltip =
|
|
||||||
"This feature is not yet available in your account's region. View supported regions here: https://aka.ms/cosmos-enable-notebooks.";
|
|
||||||
const disableButton =
|
|
||||||
!useNotebook.getState().isNotebooksEnabledForAccount && !useNotebook.getState().isNotebookEnabled;
|
|
||||||
return {
|
|
||||||
iconSrc: HostedTerminalIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
if (useNotebook.getState().isNotebookEnabled) {
|
|
||||||
container.openNotebookTerminal(ViewModels.TerminalKind.Mongo);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled: disableButton,
|
|
||||||
ariaLabel: label,
|
|
||||||
tooltipText: !disableButton ? "" : tooltip,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createOpenCassandraTerminalButton(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const label = "Open Cassandra Shell";
|
|
||||||
const tooltip =
|
|
||||||
"This feature is not yet available in your account's region. View supported regions here: https://aka.ms/cosmos-enable-notebooks.";
|
|
||||||
const disableButton =
|
|
||||||
!useNotebook.getState().isNotebooksEnabledForAccount && !useNotebook.getState().isNotebookEnabled;
|
|
||||||
return {
|
|
||||||
iconSrc: HostedTerminalIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
if (useNotebook.getState().isNotebookEnabled) {
|
|
||||||
container.openNotebookTerminal(ViewModels.TerminalKind.Cassandra);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled: disableButton,
|
|
||||||
ariaLabel: label,
|
|
||||||
tooltipText: !disableButton ? "" : tooltip,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createOpenPsqlTerminalButton(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const label = "Open PSQL Shell";
|
|
||||||
const disableButton =
|
|
||||||
(!useNotebook.getState().isNotebooksEnabledForAccount && !useNotebook.getState().isNotebookEnabled) ||
|
|
||||||
useSelectedNode.getState().isQueryCopilotCollectionSelected();
|
|
||||||
return {
|
|
||||||
iconSrc: HostedTerminalIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
if (useNotebook.getState().isNotebookEnabled) {
|
|
||||||
container.openNotebookTerminal(ViewModels.TerminalKind.Postgres);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled: disableButton,
|
|
||||||
ariaLabel: label,
|
|
||||||
tooltipText: !disableButton
|
|
||||||
? ""
|
|
||||||
: "This feature is not yet available in your account's region. View supported regions here: https://aka.ms/cosmos-enable-notebooks.",
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createNotebookWorkspaceResetButton(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const label = "Reset Workspace";
|
|
||||||
return {
|
|
||||||
iconSrc: ResetWorkspaceIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => container.resetNotebookWorkspace(),
|
|
||||||
commandButtonLabel: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
|
||||||
ariaLabel: label,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createManageGitHubAccountButton(container: Explorer): CommandButtonComponentProps {
|
|
||||||
const connectedToGitHub: boolean = container.notebookManager?.gitHubOAuthService.isLoggedIn();
|
|
||||||
const label = connectedToGitHub ? "Manage GitHub settings" : "Connect to GitHub";
|
|
||||||
const junoClient = new JunoClient();
|
|
||||||
return {
|
|
||||||
iconSrc: GitHubIcon,
|
|
||||||
iconAlt: label,
|
|
||||||
onCommandClick: () => {
|
|
||||||
useSidePanel
|
|
||||||
.getState()
|
|
||||||
.openSidePanel(
|
|
||||||
label,
|
|
||||||
<GitHubReposPanel
|
|
||||||
explorer={container}
|
|
||||||
gitHubClientProp={container.notebookManager.gitHubClient}
|
|
||||||
junoClientProp={junoClient}
|
|
||||||
/>
|
|
||||||
);
|
|
||||||
},
|
|
||||||
commandButtonLabel: label,
|
|
||||||
hasPopup: false,
|
|
||||||
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
|
||||||
ariaLabel: label,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function createStaticCommandBarButtonsForResourceToken(
|
|
||||||
container: Explorer,
|
|
||||||
selectedNodeState: SelectedNodeState
|
|
||||||
): CommandButtonComponentProps[] {
|
|
||||||
const newSqlQueryBtn = createNewSQLQueryButton(selectedNodeState);
|
|
||||||
const openQueryBtn = createOpenQueryButton(container);
|
|
||||||
|
|
||||||
const resourceTokenCollection: ViewModels.CollectionBase = useDatabases.getState().resourceTokenCollection;
|
|
||||||
const isResourceTokenCollectionNodeSelected: boolean =
|
|
||||||
resourceTokenCollection?.id() === selectedNodeState.selectedNode?.id();
|
|
||||||
newSqlQueryBtn.disabled = !isResourceTokenCollectionNodeSelected;
|
|
||||||
newSqlQueryBtn.onCommandClick = () => {
|
|
||||||
const resourceTokenCollection: ViewModels.CollectionBase = useDatabases.getState().resourceTokenCollection;
|
|
||||||
resourceTokenCollection && resourceTokenCollection.onNewQueryClick(resourceTokenCollection, undefined);
|
|
||||||
};
|
|
||||||
|
|
||||||
openQueryBtn.disabled = !isResourceTokenCollectionNodeSelected;
|
|
||||||
if (!openQueryBtn.disabled) {
|
|
||||||
openQueryBtn.children = [createOpenQueryButton(container), createOpenQueryFromDiskButton()];
|
|
||||||
}
|
|
||||||
|
|
||||||
return [newSqlQueryBtn, openQueryBtn];
|
|
||||||
}
|
|
||||||
|
|
||||||
export function createPostgreButtons(container: Explorer): CommandButtonComponentProps[] {
|
|
||||||
const openPostgreShellBtn = createOpenPsqlTerminalButton(container);
|
|
||||||
|
|
||||||
return [openPostgreShellBtn];
|
|
||||||
}
|
|
@ -0,0 +1,8 @@
|
|||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
|
||||||
|
export function applyNotebooksTemporarilyDownStyle(buttonProps: CommandButtonComponentProps, tooltip: string): void {
|
||||||
|
if (!buttonProps.isDivider) {
|
||||||
|
buttonProps.disabled = true;
|
||||||
|
buttonProps.tooltipText = tooltip;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,5 @@
|
|||||||
|
import { userContext } from "../../../../UserContext";
|
||||||
|
|
||||||
|
export function areScriptsSupported(): boolean {
|
||||||
|
return userContext.apiType === "SQL" || userContext.apiType === "Gremlin";
|
||||||
|
}
|
@ -0,0 +1,40 @@
|
|||||||
|
import * as ViewModels from "../../../../Contracts/ViewModels";
|
||||||
|
import { userContext } from "../../../../UserContext";
|
||||||
|
import HostedTerminalIcon from "../../../../images/Hosted-Terminal.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useNotebook } from "../../../Notebook/useNotebook";
|
||||||
|
import { SelectedNodeState } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createContextCommandBarButtons(
|
||||||
|
container: Explorer,
|
||||||
|
selectedNodeState: SelectedNodeState
|
||||||
|
): CommandButtonComponentProps[] {
|
||||||
|
if (selectedNodeState.isDatabaseNodeOrNoneSelected()) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (userContext.apiType !== "Mongo") {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
const label = useNotebook.getState().isShellEnabled ? "Open Mongo Shell" : "New Shell";
|
||||||
|
|
||||||
|
const newMongoShellBtn: CommandButtonComponentProps = {
|
||||||
|
iconSrc: HostedTerminalIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
||||||
|
if (useNotebook.getState().isShellEnabled) {
|
||||||
|
container.openNotebookTerminal(ViewModels.TerminalKind.Mongo);
|
||||||
|
} else {
|
||||||
|
selectedCollection && selectedCollection.onNewMongoShellClick();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
};
|
||||||
|
|
||||||
|
return [newMongoShellBtn];
|
||||||
|
}
|
@ -0,0 +1,66 @@
|
|||||||
|
import * as React from "react";
|
||||||
|
import { Platform, configContext } from "../../../../ConfigContext";
|
||||||
|
import { userContext } from "../../../../UserContext";
|
||||||
|
import { isRunningOnNationalCloud } from "../../../../Utils/CloudUtils";
|
||||||
|
import { useSidePanel } from "../../../../hooks/useSidePanel";
|
||||||
|
import FeedbackIcon from "../../../../images/Feedback-Command.svg";
|
||||||
|
import OpenInTabIcon from "../../../../images/open-in-tab.svg";
|
||||||
|
import SettingsIcon from "../../../../images/settings_15x15.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { OpenFullScreen } from "../../../OpenFullScreen";
|
||||||
|
import { SettingsPane } from "../../../Panes/SettingsPane/SettingsPane";
|
||||||
|
|
||||||
|
export function createControlCommandBarButtons(container: Explorer): CommandButtonComponentProps[] {
|
||||||
|
const buttons: CommandButtonComponentProps[] = [
|
||||||
|
{
|
||||||
|
iconSrc: SettingsIcon,
|
||||||
|
iconAlt: "Settings",
|
||||||
|
onCommandClick: () => useSidePanel.getState().openSidePanel("Settings", <SettingsPane />),
|
||||||
|
commandButtonLabel: undefined,
|
||||||
|
ariaLabel: "Settings",
|
||||||
|
tooltipText: "Settings",
|
||||||
|
hasPopup: true,
|
||||||
|
disabled: false,
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
const showOpenFullScreen =
|
||||||
|
configContext.platform === Platform.Portal && !isRunningOnNationalCloud() && userContext.apiType !== "Gremlin";
|
||||||
|
|
||||||
|
if (showOpenFullScreen) {
|
||||||
|
const label = "Open Full Screen";
|
||||||
|
const fullScreenButton: CommandButtonComponentProps = {
|
||||||
|
id: "openFullScreenBtn",
|
||||||
|
iconSrc: OpenInTabIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
useSidePanel.getState().openSidePanel("Open Full Screen", <OpenFullScreen />);
|
||||||
|
},
|
||||||
|
commandButtonLabel: undefined,
|
||||||
|
ariaLabel: label,
|
||||||
|
tooltipText: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled: !showOpenFullScreen,
|
||||||
|
className: "OpenFullScreen",
|
||||||
|
};
|
||||||
|
buttons.push(fullScreenButton);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configContext.platform !== Platform.Emulator) {
|
||||||
|
const label = "Feedback";
|
||||||
|
const feedbackButtonOptions: CommandButtonComponentProps = {
|
||||||
|
iconSrc: FeedbackIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => container.provideFeedbackEmail(),
|
||||||
|
commandButtonLabel: undefined,
|
||||||
|
ariaLabel: label,
|
||||||
|
tooltipText: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled: false,
|
||||||
|
};
|
||||||
|
buttons.push(feedbackButtonOptions);
|
||||||
|
}
|
||||||
|
|
||||||
|
return buttons;
|
||||||
|
}
|
@ -0,0 +1,15 @@
|
|||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
|
||||||
|
let counter = 0;
|
||||||
|
export function createDivider(): CommandButtonComponentProps {
|
||||||
|
const label = `divider${counter++}`;
|
||||||
|
return {
|
||||||
|
isDivider: true,
|
||||||
|
commandButtonLabel: label,
|
||||||
|
hasPopup: false,
|
||||||
|
iconSrc: undefined,
|
||||||
|
iconAlt: undefined,
|
||||||
|
onCommandClick: undefined,
|
||||||
|
ariaLabel: label,
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,34 @@
|
|||||||
|
import * as React from "react";
|
||||||
|
import { JunoClient } from "../../../../Juno/JunoClient";
|
||||||
|
import { useSidePanel } from "../../../../hooks/useSidePanel";
|
||||||
|
import GitHubIcon from "../../../../images/github.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { GitHubReposPanel } from "../../../Panes/GitHubReposPanel/GitHubReposPanel";
|
||||||
|
import { useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createManageGitHubAccountButton(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const connectedToGitHub: boolean = container.notebookManager?.gitHubOAuthService.isLoggedIn();
|
||||||
|
const label = connectedToGitHub ? "Manage GitHub settings" : "Connect to GitHub";
|
||||||
|
const junoClient = new JunoClient();
|
||||||
|
return {
|
||||||
|
iconSrc: GitHubIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
useSidePanel
|
||||||
|
.getState()
|
||||||
|
.openSidePanel(
|
||||||
|
label,
|
||||||
|
<GitHubReposPanel
|
||||||
|
explorer={container}
|
||||||
|
gitHubClientProp={container.notebookManager.gitHubClient}
|
||||||
|
junoClientProp={junoClient}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
||||||
|
ariaLabel: label,
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,17 @@
|
|||||||
|
import { getCollectionName } from "../../../../Utils/APITypeUtils";
|
||||||
|
import AddCollectionIcon from "../../../../images/AddCollection.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
|
||||||
|
export function createNewCollectionGroup(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const label = `New ${getCollectionName()}`;
|
||||||
|
return {
|
||||||
|
iconSrc: AddCollectionIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => container.onNewCollectionClicked(),
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
id: "createNewContainerCommandButton",
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,27 @@
|
|||||||
|
import * as React from "react";
|
||||||
|
import { userContext } from "../../../../UserContext";
|
||||||
|
import { getDatabaseName } from "../../../../Utils/APITypeUtils";
|
||||||
|
import { useSidePanel } from "../../../../hooks/useSidePanel";
|
||||||
|
import AddDatabaseIcon from "../../../../images/AddDatabase.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { AddDatabasePanel } from "../../../Panes/AddDatabasePanel/AddDatabasePanel";
|
||||||
|
import { useDatabases } from "../../../useDatabases";
|
||||||
|
|
||||||
|
export function createNewDatabase(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const label = "New " + getDatabaseName();
|
||||||
|
return {
|
||||||
|
iconSrc: AddDatabaseIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: async () => {
|
||||||
|
const throughputCap = userContext.databaseAccount?.properties.capacity?.totalThroughputLimit;
|
||||||
|
if (throughputCap && throughputCap !== -1) {
|
||||||
|
await useDatabases.getState().loadAllOffers();
|
||||||
|
}
|
||||||
|
useSidePanel.getState().openSidePanel("New " + getDatabaseName(), <AddDatabasePanel explorer={container} />);
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,18 @@
|
|||||||
|
import NewNotebookIcon from "../../../../images/notebook/Notebook-new.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createNewNotebookButton(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const label = "New Notebook";
|
||||||
|
return {
|
||||||
|
id: "newNotebookBtn",
|
||||||
|
iconSrc: NewNotebookIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => container.onNewNotebookClicked(),
|
||||||
|
commandButtonLabel: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
||||||
|
ariaLabel: label,
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,49 @@
|
|||||||
|
import { Action } from "Shared/Telemetry/TelemetryConstants";
|
||||||
|
import { traceOpen } from "Shared/Telemetry/TelemetryProcessor";
|
||||||
|
import { ReactTabKind, useTabs } from "hooks/useTabs";
|
||||||
|
import * as ViewModels from "../../../../Contracts/ViewModels";
|
||||||
|
import { userContext } from "../../../../UserContext";
|
||||||
|
import AddSqlQueryIcon from "../../../../images/AddSqlQuery_16x16.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import { SelectedNodeState, useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createNewSQLQueryButton(selectedNodeState: SelectedNodeState): CommandButtonComponentProps {
|
||||||
|
if (userContext.apiType === "SQL" || userContext.apiType === "Gremlin") {
|
||||||
|
const label = "New SQL Query";
|
||||||
|
return {
|
||||||
|
id: "newQueryBtn",
|
||||||
|
iconSrc: AddSqlQueryIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
if (useSelectedNode.getState().isQueryCopilotCollectionSelected()) {
|
||||||
|
useTabs.getState().openAndActivateReactTab(ReactTabKind.QueryCopilot);
|
||||||
|
traceOpen(Action.OpenQueryCopilotFromNewQuery, { apiType: userContext.apiType });
|
||||||
|
} else {
|
||||||
|
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
||||||
|
selectedCollection && selectedCollection.onNewQueryClick(selectedCollection);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
disabled: selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
||||||
|
};
|
||||||
|
} else if (userContext.apiType === "Mongo") {
|
||||||
|
const label = "New Query";
|
||||||
|
return {
|
||||||
|
id: "newQueryBtn",
|
||||||
|
iconSrc: AddSqlQueryIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
||||||
|
selectedCollection && selectedCollection.onNewMongoQueryClick(selectedCollection);
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
disabled: selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return undefined;
|
||||||
|
}
|
@ -0,0 +1,17 @@
|
|||||||
|
import ResetWorkspaceIcon from "../../../../images/notebook/Notebook-reset-workspace.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createNotebookWorkspaceResetButton(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const label = "Reset Workspace";
|
||||||
|
return {
|
||||||
|
iconSrc: ResetWorkspaceIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => container.resetNotebookWorkspace(),
|
||||||
|
commandButtonLabel: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
||||||
|
ariaLabel: label,
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,27 @@
|
|||||||
|
import * as ViewModels from "../../../../Contracts/ViewModels";
|
||||||
|
import HostedTerminalIcon from "../../../../images/Hosted-Terminal.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useNotebook } from "../../../Notebook/useNotebook";
|
||||||
|
|
||||||
|
export function createOpenCassandraTerminalButton(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const label = "Open Cassandra Shell";
|
||||||
|
const tooltip =
|
||||||
|
"This feature is not yet available in your account's region. View supported regions here: https://aka.ms/cosmos-enable-notebooks.";
|
||||||
|
const disableButton =
|
||||||
|
!useNotebook.getState().isNotebooksEnabledForAccount && !useNotebook.getState().isNotebookEnabled;
|
||||||
|
return {
|
||||||
|
iconSrc: HostedTerminalIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
if (useNotebook.getState().isNotebookEnabled) {
|
||||||
|
container.openNotebookTerminal(ViewModels.TerminalKind.Cassandra);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled: disableButton,
|
||||||
|
ariaLabel: label,
|
||||||
|
tooltipText: !disableButton ? "" : tooltip,
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,27 @@
|
|||||||
|
import * as ViewModels from "../../../../Contracts/ViewModels";
|
||||||
|
import HostedTerminalIcon from "../../../../images/Hosted-Terminal.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useNotebook } from "../../../Notebook/useNotebook";
|
||||||
|
|
||||||
|
export function createOpenMongoTerminalButton(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const label = "Open Mongo Shell";
|
||||||
|
const tooltip =
|
||||||
|
"This feature is not yet available in your account's region. View supported regions here: https://aka.ms/cosmos-enable-notebooks.";
|
||||||
|
const disableButton =
|
||||||
|
!useNotebook.getState().isNotebooksEnabledForAccount && !useNotebook.getState().isNotebookEnabled;
|
||||||
|
return {
|
||||||
|
iconSrc: HostedTerminalIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
if (useNotebook.getState().isNotebookEnabled) {
|
||||||
|
container.openNotebookTerminal(ViewModels.TerminalKind.Mongo);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled: disableButton,
|
||||||
|
ariaLabel: label,
|
||||||
|
tooltipText: !disableButton ? "" : tooltip,
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,29 @@
|
|||||||
|
import * as ViewModels from "../../../../Contracts/ViewModels";
|
||||||
|
import HostedTerminalIcon from "../../../../images/Hosted-Terminal.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useNotebook } from "../../../Notebook/useNotebook";
|
||||||
|
import { useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createOpenPsqlTerminalButton(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const label = "Open PSQL Shell";
|
||||||
|
const disableButton =
|
||||||
|
(!useNotebook.getState().isNotebooksEnabledForAccount && !useNotebook.getState().isNotebookEnabled) ||
|
||||||
|
useSelectedNode.getState().isQueryCopilotCollectionSelected();
|
||||||
|
return {
|
||||||
|
iconSrc: HostedTerminalIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
if (useNotebook.getState().isNotebookEnabled) {
|
||||||
|
container.openNotebookTerminal(ViewModels.TerminalKind.Postgres);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled: disableButton,
|
||||||
|
ariaLabel: label,
|
||||||
|
tooltipText: !disableButton
|
||||||
|
? ""
|
||||||
|
: "This feature is not yet available in your account's region. View supported regions here: https://aka.ms/cosmos-enable-notebooks.",
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,21 @@
|
|||||||
|
import * as React from "react";
|
||||||
|
import { useSidePanel } from "../../../../hooks/useSidePanel";
|
||||||
|
import BrowseQueriesIcon from "../../../../images/BrowseQuery.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { BrowseQueriesPane } from "../../../Panes/BrowseQueriesPane/BrowseQueriesPane";
|
||||||
|
import { useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createOpenQueryButton(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const label = "Open Query";
|
||||||
|
return {
|
||||||
|
iconSrc: BrowseQueriesIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () =>
|
||||||
|
useSidePanel.getState().openSidePanel("Open Saved Queries", <BrowseQueriesPane explorer={container} />),
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,19 @@
|
|||||||
|
import * as React from "react";
|
||||||
|
import { useSidePanel } from "../../../../hooks/useSidePanel";
|
||||||
|
import OpenQueryFromDiskIcon from "../../../../images/OpenQueryFromDisk.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import { LoadQueryPane } from "../../../Panes/LoadQueryPane/LoadQueryPane";
|
||||||
|
import { useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createOpenQueryFromDiskButton(): CommandButtonComponentProps {
|
||||||
|
const label = "Open Query From Disk";
|
||||||
|
return {
|
||||||
|
iconSrc: OpenQueryFromDiskIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => useSidePanel.getState().openSidePanel("Load Query", <LoadQueryPane />),
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,35 @@
|
|||||||
|
import * as Constants from "../../../../Common/Constants";
|
||||||
|
import { Platform, configContext } from "../../../../ConfigContext";
|
||||||
|
import { userContext } from "../../../../UserContext";
|
||||||
|
import SynapseIcon from "../../../../images/synapse-link.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useNotebook } from "../../../Notebook/useNotebook";
|
||||||
|
import { useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createOpenSynapseLinkDialogButton(container: Explorer): CommandButtonComponentProps {
|
||||||
|
if (configContext.platform === Platform.Emulator) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (userContext?.databaseAccount?.properties?.enableAnalyticalStorage) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
const capabilities = userContext?.databaseAccount?.properties?.capabilities || [];
|
||||||
|
if (capabilities.some((capability) => capability.name === Constants.CapabilityNames.EnableStorageAnalytics)) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
const label = "Enable Azure Synapse Link";
|
||||||
|
return {
|
||||||
|
iconSrc: SynapseIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => container.openEnableSynapseLinkDialog(),
|
||||||
|
commandButtonLabel: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled:
|
||||||
|
useSelectedNode.getState().isQueryCopilotCollectionSelected() || useNotebook.getState().isSynapseLinkUpdating,
|
||||||
|
ariaLabel: label,
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,18 @@
|
|||||||
|
import * as ViewModels from "../../../../Contracts/ViewModels";
|
||||||
|
import CosmosTerminalIcon from "../../../../images/Cosmos-Terminal.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createOpenTerminalButton(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const label = "Open Terminal";
|
||||||
|
return {
|
||||||
|
iconSrc: CosmosTerminalIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => container.openNotebookTerminal(ViewModels.TerminalKind.Default),
|
||||||
|
commandButtonLabel: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
||||||
|
ariaLabel: label,
|
||||||
|
};
|
||||||
|
}
|
@ -0,0 +1,9 @@
|
|||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { createOpenPsqlTerminalButton } from "./createOpenPsqlTerminalButton";
|
||||||
|
|
||||||
|
export function createPostgreButtons(container: Explorer): CommandButtonComponentProps[] {
|
||||||
|
const openPostgreShellBtn = createOpenPsqlTerminalButton(container);
|
||||||
|
|
||||||
|
return [openPostgreShellBtn];
|
||||||
|
}
|
@ -0,0 +1,73 @@
|
|||||||
|
import { CommandButtonComponentProps } from "Explorer/Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import { SelectedNodeState, useSelectedNode } from "Explorer/useSelectedNode";
|
||||||
|
import * as ViewModels from "../../../../Contracts/ViewModels";
|
||||||
|
import AddStoredProcedureIcon from "../../../../images/AddStoredProcedure.svg";
|
||||||
|
import AddTriggerIcon from "../../../../images/AddTrigger.svg";
|
||||||
|
import AddUdfIcon from "../../../../images/AddUdf.svg";
|
||||||
|
import { areScriptsSupported } from "./areScriptsSupported";
|
||||||
|
|
||||||
|
export function createScriptCommandButtons(selectedNodeState: SelectedNodeState): CommandButtonComponentProps[] {
|
||||||
|
const buttons: CommandButtonComponentProps[] = [];
|
||||||
|
|
||||||
|
const shouldEnableScriptsCommands: boolean =
|
||||||
|
!selectedNodeState.isDatabaseNodeOrNoneSelected() && areScriptsSupported();
|
||||||
|
|
||||||
|
if (shouldEnableScriptsCommands) {
|
||||||
|
const label = "New Stored Procedure";
|
||||||
|
const newStoredProcedureBtn: CommandButtonComponentProps = {
|
||||||
|
iconSrc: AddStoredProcedureIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
||||||
|
selectedCollection && selectedCollection.onNewStoredProcedureClick(selectedCollection);
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
disabled:
|
||||||
|
useSelectedNode.getState().isQueryCopilotCollectionSelected() ||
|
||||||
|
selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
||||||
|
};
|
||||||
|
buttons.push(newStoredProcedureBtn);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (shouldEnableScriptsCommands) {
|
||||||
|
const label = "New UDF";
|
||||||
|
const newUserDefinedFunctionBtn: CommandButtonComponentProps = {
|
||||||
|
iconSrc: AddUdfIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
||||||
|
selectedCollection && selectedCollection.onNewUserDefinedFunctionClick(selectedCollection);
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
disabled:
|
||||||
|
useSelectedNode.getState().isQueryCopilotCollectionSelected() ||
|
||||||
|
selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
||||||
|
};
|
||||||
|
buttons.push(newUserDefinedFunctionBtn);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (shouldEnableScriptsCommands) {
|
||||||
|
const label = "New Trigger";
|
||||||
|
const newTriggerBtn: CommandButtonComponentProps = {
|
||||||
|
iconSrc: AddTriggerIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
||||||
|
selectedCollection && selectedCollection.onNewTriggerClick(selectedCollection);
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
disabled:
|
||||||
|
useSelectedNode.getState().isQueryCopilotCollectionSelected() ||
|
||||||
|
selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
||||||
|
};
|
||||||
|
buttons.push(newTriggerBtn);
|
||||||
|
}
|
||||||
|
|
||||||
|
return buttons;
|
||||||
|
}
|
@ -0,0 +1,140 @@
|
|||||||
|
import { createScriptCommandButtons } from "Explorer/Menus/CommandBar/CommandButtonsFactories/createScriptCommandButtons";
|
||||||
|
import * as Constants from "../../../../Common/Constants";
|
||||||
|
import { configContext } from "../../../../ConfigContext";
|
||||||
|
import * as ViewModels from "../../../../Contracts/ViewModels";
|
||||||
|
import { userContext } from "../../../../UserContext";
|
||||||
|
import AddStoredProcedureIcon from "../../../../images/AddStoredProcedure.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useNotebook } from "../../../Notebook/useNotebook";
|
||||||
|
import { SelectedNodeState, useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
import { applyNotebooksTemporarilyDownStyle } from "./applyNotebooksTemporarilyDownStyle";
|
||||||
|
import { areScriptsSupported } from "./areScriptsSupported";
|
||||||
|
import { createDivider } from "./createDivider";
|
||||||
|
import { createManageGitHubAccountButton } from "./createManageGitHubAccountButton";
|
||||||
|
import { createNewCollectionGroup } from "./createNewCollectionGroup";
|
||||||
|
import { createNewDatabase } from "./createNewDatabase";
|
||||||
|
import { createNewNotebookButton } from "./createNewNotebookButton";
|
||||||
|
import { createNewSQLQueryButton } from "./createNewSQLQueryButton";
|
||||||
|
import { createNotebookWorkspaceResetButton } from "./createNotebookWorkspaceResetButton";
|
||||||
|
import { createOpenCassandraTerminalButton } from "./createOpenCassandraTerminalButton";
|
||||||
|
import { createOpenMongoTerminalButton } from "./createOpenMongoTerminalButton";
|
||||||
|
import { createOpenQueryButton } from "./createOpenQueryButton";
|
||||||
|
import { createOpenQueryFromDiskButton } from "./createOpenQueryFromDiskButton";
|
||||||
|
import { createOpenSynapseLinkDialogButton } from "./createOpenSynapseLinkDialogButton";
|
||||||
|
import { createOpenTerminalButton } from "./createOpenTerminalButton";
|
||||||
|
import { createuploadNotebookButton } from "./createuploadNotebookButton";
|
||||||
|
|
||||||
|
export function createStaticCommandBarButtons(
|
||||||
|
container: Explorer,
|
||||||
|
selectedNodeState: SelectedNodeState
|
||||||
|
): CommandButtonComponentProps[] {
|
||||||
|
const newCollectionBtn = createNewCollectionGroup(container);
|
||||||
|
const buttons: CommandButtonComponentProps[] = [];
|
||||||
|
|
||||||
|
buttons.push(newCollectionBtn);
|
||||||
|
if (userContext.apiType !== "Tables" && userContext.apiType !== "Cassandra") {
|
||||||
|
const addSynapseLink = createOpenSynapseLinkDialogButton(container);
|
||||||
|
|
||||||
|
if (addSynapseLink) {
|
||||||
|
buttons.push(createDivider());
|
||||||
|
buttons.push(addSynapseLink);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (userContext.apiType !== "Tables") {
|
||||||
|
newCollectionBtn.children = [createNewCollectionGroup(container)];
|
||||||
|
const newDatabaseBtn = createNewDatabase(container);
|
||||||
|
newCollectionBtn.children.push(newDatabaseBtn);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (useNotebook.getState().isNotebookEnabled) {
|
||||||
|
buttons.push(createDivider());
|
||||||
|
const notebookButtons: CommandButtonComponentProps[] = [];
|
||||||
|
|
||||||
|
const newNotebookButton = createNewNotebookButton(container);
|
||||||
|
newNotebookButton.children = [createNewNotebookButton(container), createuploadNotebookButton(container)];
|
||||||
|
notebookButtons.push(newNotebookButton);
|
||||||
|
|
||||||
|
if (container.notebookManager?.gitHubOAuthService) {
|
||||||
|
notebookButtons.push(createManageGitHubAccountButton(container));
|
||||||
|
}
|
||||||
|
if (useNotebook.getState().isPhoenixFeatures && configContext.isTerminalEnabled) {
|
||||||
|
notebookButtons.push(createOpenTerminalButton(container));
|
||||||
|
}
|
||||||
|
if (useNotebook.getState().isPhoenixNotebooks && selectedNodeState.isConnectedToContainer()) {
|
||||||
|
notebookButtons.push(createNotebookWorkspaceResetButton(container));
|
||||||
|
}
|
||||||
|
if (
|
||||||
|
(userContext.apiType === "Mongo" &&
|
||||||
|
useNotebook.getState().isShellEnabled &&
|
||||||
|
selectedNodeState.isDatabaseNodeOrNoneSelected()) ||
|
||||||
|
userContext.apiType === "Cassandra"
|
||||||
|
) {
|
||||||
|
notebookButtons.push(createDivider());
|
||||||
|
if (userContext.apiType === "Cassandra") {
|
||||||
|
notebookButtons.push(createOpenCassandraTerminalButton(container));
|
||||||
|
} else {
|
||||||
|
notebookButtons.push(createOpenMongoTerminalButton(container));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
notebookButtons.forEach((btn) => {
|
||||||
|
if (btn.commandButtonLabel.indexOf("Cassandra") !== -1) {
|
||||||
|
if (!useNotebook.getState().isPhoenixFeatures) {
|
||||||
|
applyNotebooksTemporarilyDownStyle(btn, Constants.Notebook.cassandraShellTemporarilyDownMsg);
|
||||||
|
}
|
||||||
|
} else if (btn.commandButtonLabel.indexOf("Mongo") !== -1) {
|
||||||
|
if (!useNotebook.getState().isPhoenixFeatures) {
|
||||||
|
applyNotebooksTemporarilyDownStyle(btn, Constants.Notebook.mongoShellTemporarilyDownMsg);
|
||||||
|
}
|
||||||
|
} else if (btn.commandButtonLabel.indexOf("Open Terminal") !== -1) {
|
||||||
|
if (!useNotebook.getState().isPhoenixFeatures) {
|
||||||
|
applyNotebooksTemporarilyDownStyle(btn, Constants.Notebook.temporarilyDownMsg);
|
||||||
|
}
|
||||||
|
} else if (!useNotebook.getState().isPhoenixNotebooks) {
|
||||||
|
applyNotebooksTemporarilyDownStyle(btn, Constants.Notebook.temporarilyDownMsg);
|
||||||
|
}
|
||||||
|
buttons.push(btn);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!selectedNodeState.isDatabaseNodeOrNoneSelected()) {
|
||||||
|
const isQuerySupported = userContext.apiType === "SQL" || userContext.apiType === "Gremlin";
|
||||||
|
|
||||||
|
if (isQuerySupported) {
|
||||||
|
buttons.push(createDivider());
|
||||||
|
const newSqlQueryBtn = createNewSQLQueryButton(selectedNodeState);
|
||||||
|
buttons.push(newSqlQueryBtn);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isQuerySupported && selectedNodeState.findSelectedCollection()) {
|
||||||
|
const openQueryBtn = createOpenQueryButton(container);
|
||||||
|
openQueryBtn.children = [createOpenQueryButton(container), createOpenQueryFromDiskButton()];
|
||||||
|
buttons.push(openQueryBtn);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (areScriptsSupported()) {
|
||||||
|
const label = "New Stored Procedure";
|
||||||
|
const newStoredProcedureBtn: CommandButtonComponentProps = {
|
||||||
|
iconSrc: AddStoredProcedureIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => {
|
||||||
|
const selectedCollection: ViewModels.Collection = selectedNodeState.findSelectedCollection();
|
||||||
|
selectedCollection && selectedCollection.onNewStoredProcedureClick(selectedCollection);
|
||||||
|
},
|
||||||
|
commandButtonLabel: label,
|
||||||
|
ariaLabel: label,
|
||||||
|
hasPopup: true,
|
||||||
|
disabled:
|
||||||
|
useSelectedNode.getState().isQueryCopilotCollectionSelected() ||
|
||||||
|
selectedNodeState.isDatabaseNodeOrNoneSelected(),
|
||||||
|
};
|
||||||
|
|
||||||
|
newStoredProcedureBtn.children = createScriptCommandButtons(selectedNodeState);
|
||||||
|
buttons.push(newStoredProcedureBtn);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return buttons;
|
||||||
|
}
|
@ -0,0 +1,32 @@
|
|||||||
|
import * as ViewModels from "../../../../Contracts/ViewModels";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useDatabases } from "../../../useDatabases";
|
||||||
|
import { SelectedNodeState } from "../../../useSelectedNode";
|
||||||
|
import { createNewSQLQueryButton } from "./createNewSQLQueryButton";
|
||||||
|
import { createOpenQueryButton } from "./createOpenQueryButton";
|
||||||
|
import { createOpenQueryFromDiskButton } from "./createOpenQueryFromDiskButton";
|
||||||
|
|
||||||
|
export function createStaticCommandBarButtonsForResourceToken(
|
||||||
|
container: Explorer,
|
||||||
|
selectedNodeState: SelectedNodeState
|
||||||
|
): CommandButtonComponentProps[] {
|
||||||
|
const newSqlQueryBtn = createNewSQLQueryButton(selectedNodeState);
|
||||||
|
const openQueryBtn = createOpenQueryButton(container);
|
||||||
|
|
||||||
|
const resourceTokenCollection: ViewModels.CollectionBase = useDatabases.getState().resourceTokenCollection;
|
||||||
|
const isResourceTokenCollectionNodeSelected: boolean =
|
||||||
|
resourceTokenCollection?.id() === selectedNodeState.selectedNode?.id();
|
||||||
|
newSqlQueryBtn.disabled = !isResourceTokenCollectionNodeSelected;
|
||||||
|
newSqlQueryBtn.onCommandClick = () => {
|
||||||
|
const resourceTokenCollection: ViewModels.CollectionBase = useDatabases.getState().resourceTokenCollection;
|
||||||
|
resourceTokenCollection && resourceTokenCollection.onNewQueryClick(resourceTokenCollection, undefined);
|
||||||
|
};
|
||||||
|
|
||||||
|
openQueryBtn.disabled = !isResourceTokenCollectionNodeSelected;
|
||||||
|
if (!openQueryBtn.disabled) {
|
||||||
|
openQueryBtn.children = [createOpenQueryButton(container), createOpenQueryFromDiskButton()];
|
||||||
|
}
|
||||||
|
|
||||||
|
return [newSqlQueryBtn, openQueryBtn];
|
||||||
|
}
|
@ -0,0 +1,17 @@
|
|||||||
|
import NewNotebookIcon from "../../../../images/notebook/Notebook-new.svg";
|
||||||
|
import { CommandButtonComponentProps } from "../../../Controls/CommandButton/CommandButtonComponent";
|
||||||
|
import Explorer from "../../../Explorer";
|
||||||
|
import { useSelectedNode } from "../../../useSelectedNode";
|
||||||
|
|
||||||
|
export function createuploadNotebookButton(container: Explorer): CommandButtonComponentProps {
|
||||||
|
const label = "Upload to Notebook Server";
|
||||||
|
return {
|
||||||
|
iconSrc: NewNotebookIcon,
|
||||||
|
iconAlt: label,
|
||||||
|
onCommandClick: () => container.openUploadFilePanel(),
|
||||||
|
commandButtonLabel: label,
|
||||||
|
hasPopup: false,
|
||||||
|
disabled: useSelectedNode.getState().isQueryCopilotCollectionSelected(),
|
||||||
|
ariaLabel: label,
|
||||||
|
};
|
||||||
|
}
|
@ -284,7 +284,7 @@ export const QueryCopilotTab: React.FC<QueryCopilotTabProps> = ({ explorer }: Qu
|
|||||||
|
|
||||||
const getCommandbarButtons = (): CommandButtonComponentProps[] => {
|
const getCommandbarButtons = (): CommandButtonComponentProps[] => {
|
||||||
const executeQueryBtnLabel = selectedQuery ? "Execute Selection" : "Execute Query";
|
const executeQueryBtnLabel = selectedQuery ? "Execute Selection" : "Execute Query";
|
||||||
const executeQueryBtn = {
|
const executeQueryBtn: CommandButtonComponentProps = {
|
||||||
iconSrc: ExecuteQueryIcon,
|
iconSrc: ExecuteQueryIcon,
|
||||||
iconAlt: executeQueryBtnLabel,
|
iconAlt: executeQueryBtnLabel,
|
||||||
onCommandClick: () => onExecuteQueryClick(),
|
onCommandClick: () => onExecuteQueryClick(),
|
||||||
@ -294,7 +294,7 @@ export const QueryCopilotTab: React.FC<QueryCopilotTabProps> = ({ explorer }: Qu
|
|||||||
disabled: query?.trim() === "",
|
disabled: query?.trim() === "",
|
||||||
};
|
};
|
||||||
|
|
||||||
const saveQueryBtn = {
|
const saveQueryBtn: CommandButtonComponentProps = {
|
||||||
iconSrc: SaveQueryIcon,
|
iconSrc: SaveQueryIcon,
|
||||||
iconAlt: "Save Query",
|
iconAlt: "Save Query",
|
||||||
onCommandClick: () =>
|
onCommandClick: () =>
|
||||||
@ -306,7 +306,7 @@ export const QueryCopilotTab: React.FC<QueryCopilotTabProps> = ({ explorer }: Qu
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Sample Prompts temporary disabled due current design
|
// Sample Prompts temporary disabled due current design
|
||||||
// const samplePromptsBtn = {
|
// const samplePromptsBtn: CommandButtonComponentProps = {
|
||||||
// iconSrc: SamplePromptsIcon,
|
// iconSrc: SamplePromptsIcon,
|
||||||
// iconAlt: "Sample Prompts",
|
// iconAlt: "Sample Prompts",
|
||||||
// onCommandClick: () => setIsSamplePromptsOpen(true),
|
// onCommandClick: () => setIsSamplePromptsOpen(true),
|
||||||
|
@ -6,16 +6,16 @@ import DiscardIcon from "../../../images/discard.svg";
|
|||||||
import SaveIcon from "../../../images/save-cosmos.svg";
|
import SaveIcon from "../../../images/save-cosmos.svg";
|
||||||
import * as Constants from "../../Common/Constants";
|
import * as Constants from "../../Common/Constants";
|
||||||
import { DocumentsGridMetrics, KeyCodes } from "../../Common/Constants";
|
import { DocumentsGridMetrics, KeyCodes } from "../../Common/Constants";
|
||||||
import { createDocument } from "../../Common/dataAccess/createDocument";
|
|
||||||
import { deleteConflict } from "../../Common/dataAccess/deleteConflict";
|
|
||||||
import { deleteDocument } from "../../Common/dataAccess/deleteDocument";
|
|
||||||
import { queryConflicts } from "../../Common/dataAccess/queryConflicts";
|
|
||||||
import { updateDocument } from "../../Common/dataAccess/updateDocument";
|
|
||||||
import editable from "../../Common/EditableUtility";
|
import editable from "../../Common/EditableUtility";
|
||||||
import { getErrorMessage, getErrorStack } from "../../Common/ErrorHandlingUtils";
|
import { getErrorMessage, getErrorStack } from "../../Common/ErrorHandlingUtils";
|
||||||
import * as HeadersUtility from "../../Common/HeadersUtility";
|
import * as HeadersUtility from "../../Common/HeadersUtility";
|
||||||
import { MinimalQueryIterator } from "../../Common/IteratorUtilities";
|
import { MinimalQueryIterator } from "../../Common/IteratorUtilities";
|
||||||
import { Splitter, SplitterBounds, SplitterDirection } from "../../Common/Splitter";
|
import { Splitter, SplitterBounds, SplitterDirection } from "../../Common/Splitter";
|
||||||
|
import { createDocument } from "../../Common/dataAccess/createDocument";
|
||||||
|
import { deleteConflict } from "../../Common/dataAccess/deleteConflict";
|
||||||
|
import { deleteDocument } from "../../Common/dataAccess/deleteDocument";
|
||||||
|
import { queryConflicts } from "../../Common/dataAccess/queryConflicts";
|
||||||
|
import { updateDocument } from "../../Common/dataAccess/updateDocument";
|
||||||
import * as DataModels from "../../Contracts/DataModels";
|
import * as DataModels from "../../Contracts/DataModels";
|
||||||
import * as ViewModels from "../../Contracts/ViewModels";
|
import * as ViewModels from "../../Contracts/ViewModels";
|
||||||
import { Action } from "../../Shared/Telemetry/TelemetryConstants";
|
import { Action } from "../../Shared/Telemetry/TelemetryConstants";
|
||||||
|
@ -1,7 +1,8 @@
|
|||||||
import { stringifyNotebook, toJS } from "@nteract/commutable";
|
import { stringifyNotebook, toJS } from "@nteract/commutable";
|
||||||
|
import * as createDivider from "Explorer/Menus/CommandBar/CommandButtonsFactories/createDivider";
|
||||||
|
import { userContext } from "UserContext";
|
||||||
import * as ko from "knockout";
|
import * as ko from "knockout";
|
||||||
import * as Q from "q";
|
import * as Q from "q";
|
||||||
import { userContext } from "UserContext";
|
|
||||||
import ClearAllOutputsIcon from "../../../images/notebook/Notebook-clear-all-outputs.svg";
|
import ClearAllOutputsIcon from "../../../images/notebook/Notebook-clear-all-outputs.svg";
|
||||||
import CopyIcon from "../../../images/notebook/Notebook-copy.svg";
|
import CopyIcon from "../../../images/notebook/Notebook-copy.svg";
|
||||||
import CutIcon from "../../../images/notebook/Notebook-cut.svg";
|
import CutIcon from "../../../images/notebook/Notebook-cut.svg";
|
||||||
@ -12,17 +13,16 @@ import RunAllIcon from "../../../images/notebook/Notebook-run-all.svg";
|
|||||||
import RunIcon from "../../../images/notebook/Notebook-run.svg";
|
import RunIcon from "../../../images/notebook/Notebook-run.svg";
|
||||||
import { default as InterruptKernelIcon, default as KillKernelIcon } from "../../../images/notebook/Notebook-stop.svg";
|
import { default as InterruptKernelIcon, default as KillKernelIcon } from "../../../images/notebook/Notebook-stop.svg";
|
||||||
import SaveIcon from "../../../images/save-cosmos.svg";
|
import SaveIcon from "../../../images/save-cosmos.svg";
|
||||||
import { useNotebookSnapshotStore } from "../../hooks/useNotebookSnapshotStore";
|
|
||||||
import { Action, ActionModifiers, Source } from "../../Shared/Telemetry/TelemetryConstants";
|
import { Action, ActionModifiers, Source } from "../../Shared/Telemetry/TelemetryConstants";
|
||||||
import * as TelemetryProcessor from "../../Shared/Telemetry/TelemetryProcessor";
|
import * as TelemetryProcessor from "../../Shared/Telemetry/TelemetryProcessor";
|
||||||
import * as NotebookConfigurationUtils from "../../Utils/NotebookConfigurationUtils";
|
import * as NotebookConfigurationUtils from "../../Utils/NotebookConfigurationUtils";
|
||||||
import { logConsoleInfo } from "../../Utils/NotificationConsoleUtils";
|
import { logConsoleInfo } from "../../Utils/NotificationConsoleUtils";
|
||||||
|
import { useNotebookSnapshotStore } from "../../hooks/useNotebookSnapshotStore";
|
||||||
import { CommandButtonComponentProps } from "../Controls/CommandButton/CommandButtonComponent";
|
import { CommandButtonComponentProps } from "../Controls/CommandButton/CommandButtonComponent";
|
||||||
import { useDialog } from "../Controls/Dialog";
|
import { useDialog } from "../Controls/Dialog";
|
||||||
import * as CommandBarComponentButtonFactory from "../Menus/CommandBar/CommandBarComponentButtonFactory";
|
|
||||||
import { KernelSpecsDisplay } from "../Notebook/NotebookClientV2";
|
import { KernelSpecsDisplay } from "../Notebook/NotebookClientV2";
|
||||||
import * as CdbActions from "../Notebook/NotebookComponent/actions";
|
|
||||||
import { NotebookComponentAdapter } from "../Notebook/NotebookComponent/NotebookComponentAdapter";
|
import { NotebookComponentAdapter } from "../Notebook/NotebookComponent/NotebookComponentAdapter";
|
||||||
|
import * as CdbActions from "../Notebook/NotebookComponent/actions";
|
||||||
import { CdbAppState, SnapshotRequest } from "../Notebook/NotebookComponent/types";
|
import { CdbAppState, SnapshotRequest } from "../Notebook/NotebookComponent/types";
|
||||||
import { NotebookContentItem } from "../Notebook/NotebookContentItem";
|
import { NotebookContentItem } from "../Notebook/NotebookContentItem";
|
||||||
import { NotebookUtil } from "../Notebook/NotebookUtil";
|
import { NotebookUtil } from "../Notebook/NotebookUtil";
|
||||||
@ -118,7 +118,7 @@ export default class NotebookTabV2 extends NotebookTabBase {
|
|||||||
const cellMarkdownType = "markdown";
|
const cellMarkdownType = "markdown";
|
||||||
const cellRawType = "raw";
|
const cellRawType = "raw";
|
||||||
|
|
||||||
const saveButtonChildren = [];
|
const saveButtonChildren: CommandButtonComponentProps[] = [];
|
||||||
if (this.container.notebookManager?.gitHubOAuthService.isLoggedIn()) {
|
if (this.container.notebookManager?.gitHubOAuthService.isLoggedIn()) {
|
||||||
saveButtonChildren.push({
|
saveButtonChildren.push({
|
||||||
iconName: copyToLabel,
|
iconName: copyToLabel,
|
||||||
@ -272,7 +272,7 @@ export default class NotebookTabV2 extends NotebookTabBase {
|
|||||||
hasPopup: false,
|
hasPopup: false,
|
||||||
disabled: false,
|
disabled: false,
|
||||||
},
|
},
|
||||||
CommandBarComponentButtonFactory.createDivider(),
|
createDivider.createDivider(),
|
||||||
{
|
{
|
||||||
iconSrc: null,
|
iconSrc: null,
|
||||||
iconAlt: null,
|
iconAlt: null,
|
||||||
|
@ -7,8 +7,8 @@ import ExecuteQueryIcon from "../../../images/ExecuteQuery.svg";
|
|||||||
import QueryBuilderIcon from "../../../images/Query-Builder.svg";
|
import QueryBuilderIcon from "../../../images/Query-Builder.svg";
|
||||||
import QueryTextIcon from "../../../images/Query-Text.svg";
|
import QueryTextIcon from "../../../images/Query-Text.svg";
|
||||||
import * as ViewModels from "../../Contracts/ViewModels";
|
import * as ViewModels from "../../Contracts/ViewModels";
|
||||||
import { useSidePanel } from "../../hooks/useSidePanel";
|
|
||||||
import { userContext } from "../../UserContext";
|
import { userContext } from "../../UserContext";
|
||||||
|
import { useSidePanel } from "../../hooks/useSidePanel";
|
||||||
import { CommandButtonComponentProps } from "../Controls/CommandButton/CommandButtonComponent";
|
import { CommandButtonComponentProps } from "../Controls/CommandButton/CommandButtonComponent";
|
||||||
import Explorer from "../Explorer";
|
import Explorer from "../Explorer";
|
||||||
import { AddTableEntityPanel } from "../Panes/Tables/AddTableEntityPanel";
|
import { AddTableEntityPanel } from "../Panes/Tables/AddTableEntityPanel";
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import { Resource, StoredProcedureDefinition } from "@azure/cosmos";
|
import { Resource, StoredProcedureDefinition } from "@azure/cosmos";
|
||||||
import { Pivot, PivotItem } from "@fluentui/react";
|
import { Pivot, PivotItem } from "@fluentui/react";
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import DiscardIcon from "../../../../images/discard.svg";
|
|
||||||
import ExecuteQueryIcon from "../../../../images/ExecuteQuery.svg";
|
import ExecuteQueryIcon from "../../../../images/ExecuteQuery.svg";
|
||||||
|
import DiscardIcon from "../../../../images/discard.svg";
|
||||||
import SaveIcon from "../../../../images/save-cosmos.svg";
|
import SaveIcon from "../../../../images/save-cosmos.svg";
|
||||||
import { NormalizedEventKey } from "../../../Common/Constants";
|
import { NormalizedEventKey } from "../../../Common/Constants";
|
||||||
import { createStoredProcedure } from "../../../Common/dataAccess/createStoredProcedure";
|
import { createStoredProcedure } from "../../../Common/dataAccess/createStoredProcedure";
|
||||||
|
@ -4,9 +4,9 @@ import React, { Component } from "react";
|
|||||||
import DiscardIcon from "../../../images/discard.svg";
|
import DiscardIcon from "../../../images/discard.svg";
|
||||||
import SaveIcon from "../../../images/save-cosmos.svg";
|
import SaveIcon from "../../../images/save-cosmos.svg";
|
||||||
import * as Constants from "../../Common/Constants";
|
import * as Constants from "../../Common/Constants";
|
||||||
|
import { getErrorMessage, getErrorStack } from "../../Common/ErrorHandlingUtils";
|
||||||
import { createTrigger } from "../../Common/dataAccess/createTrigger";
|
import { createTrigger } from "../../Common/dataAccess/createTrigger";
|
||||||
import { updateTrigger } from "../../Common/dataAccess/updateTrigger";
|
import { updateTrigger } from "../../Common/dataAccess/updateTrigger";
|
||||||
import { getErrorMessage, getErrorStack } from "../../Common/ErrorHandlingUtils";
|
|
||||||
import * as ViewModels from "../../Contracts/ViewModels";
|
import * as ViewModels from "../../Contracts/ViewModels";
|
||||||
import { Action } from "../../Shared/Telemetry/TelemetryConstants";
|
import { Action } from "../../Shared/Telemetry/TelemetryConstants";
|
||||||
import * as TelemetryProcessor from "../../Shared/Telemetry/TelemetryProcessor";
|
import * as TelemetryProcessor from "../../Shared/Telemetry/TelemetryProcessor";
|
||||||
|
@ -4,9 +4,9 @@ import React, { Component } from "react";
|
|||||||
import DiscardIcon from "../../../images/discard.svg";
|
import DiscardIcon from "../../../images/discard.svg";
|
||||||
import SaveIcon from "../../../images/save-cosmos.svg";
|
import SaveIcon from "../../../images/save-cosmos.svg";
|
||||||
import * as Constants from "../../Common/Constants";
|
import * as Constants from "../../Common/Constants";
|
||||||
|
import { getErrorMessage, getErrorStack } from "../../Common/ErrorHandlingUtils";
|
||||||
import { createUserDefinedFunction } from "../../Common/dataAccess/createUserDefinedFunction";
|
import { createUserDefinedFunction } from "../../Common/dataAccess/createUserDefinedFunction";
|
||||||
import { updateUserDefinedFunction } from "../../Common/dataAccess/updateUserDefinedFunction";
|
import { updateUserDefinedFunction } from "../../Common/dataAccess/updateUserDefinedFunction";
|
||||||
import { getErrorMessage, getErrorStack } from "../../Common/ErrorHandlingUtils";
|
|
||||||
import * as ViewModels from "../../Contracts/ViewModels";
|
import * as ViewModels from "../../Contracts/ViewModels";
|
||||||
import { Action } from "../../Shared/Telemetry/TelemetryConstants";
|
import { Action } from "../../Shared/Telemetry/TelemetryConstants";
|
||||||
import * as TelemetryProcessor from "../../Shared/Telemetry/TelemetryProcessor";
|
import * as TelemetryProcessor from "../../Shared/Telemetry/TelemetryProcessor";
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import * as React from "react";
|
import * as React from "react";
|
||||||
import { CommandButtonComponent } from "../../../Explorer/Controls/CommandButton/CommandButtonComponent";
|
|
||||||
import FeedbackIcon from "../../../../images/Feedback.svg";
|
import FeedbackIcon from "../../../../images/Feedback.svg";
|
||||||
|
import { CommandButtonComponent } from "../../../Explorer/Controls/CommandButton/CommandButtonComponent";
|
||||||
|
|
||||||
export const FeedbackCommandButton: React.FunctionComponent = () => {
|
export const FeedbackCommandButton: React.FunctionComponent = () => {
|
||||||
return (
|
return (
|
||||||
|
Loading…
x
Reference in New Issue
Block a user