mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2025-04-20 08:37:59 +01:00
65 lines
2.6 KiB
TypeScript
65 lines
2.6 KiB
TypeScript
import { useCommandBar } from "Explorer/Menus/CommandBar/CommandBarComponentAdapter";
|
|
import TabsBase from "Explorer/Tabs/TabsBase";
|
|
import { useSelectedNode } from "Explorer/useSelectedNode";
|
|
import { useTabs } from "hooks/useTabs";
|
|
import React, { useEffect, useState } from "react";
|
|
import CosmosDBIcon from "../../../images/Azure-Cosmos-DB.svg";
|
|
import CollectionIcon from "../../../images/tree-collection.svg";
|
|
import * as ViewModels from "../../Contracts/ViewModels";
|
|
import * as ResourceTreeContextMenuButtonFactory from "../ContextMenuButtonFactory";
|
|
import { TreeComponent, TreeNode } from "../Controls/TreeComponent/TreeComponent";
|
|
|
|
export const SampleDataTree = ({
|
|
sampleDataResourceTokenCollection,
|
|
}: {
|
|
sampleDataResourceTokenCollection: ViewModels.CollectionBase;
|
|
}): JSX.Element => {
|
|
const [root, setRoot] = useState<TreeNode | undefined>(undefined);
|
|
|
|
useEffect(() => {
|
|
if (sampleDataResourceTokenCollection) {
|
|
const updatedSampleTree: TreeNode = {
|
|
label: sampleDataResourceTokenCollection.databaseId,
|
|
isExpanded: false,
|
|
iconSrc: CosmosDBIcon,
|
|
className: "databaseHeader",
|
|
children: [
|
|
{
|
|
label: sampleDataResourceTokenCollection.id(),
|
|
iconSrc: CollectionIcon,
|
|
isExpanded: false,
|
|
className: "dataResourceTree",
|
|
contextMenu: ResourceTreeContextMenuButtonFactory.createSampleCollectionContextMenuButton(),
|
|
onClick: () => {
|
|
// Rewritten version of expandCollapseCollection
|
|
useSelectedNode.getState().setSelectedNode(sampleDataResourceTokenCollection);
|
|
useCommandBar.getState().setContextButtons([]);
|
|
useTabs().refreshActiveTab(
|
|
(tab: TabsBase) =>
|
|
tab.collection?.id() === sampleDataResourceTokenCollection.id() &&
|
|
tab.collection.databaseId === sampleDataResourceTokenCollection.databaseId
|
|
);
|
|
},
|
|
isSelected: () =>
|
|
useSelectedNode
|
|
.getState()
|
|
.isDataNodeSelected(
|
|
sampleDataResourceTokenCollection.databaseId,
|
|
sampleDataResourceTokenCollection.id()
|
|
),
|
|
onContextMenuOpen: () => useSelectedNode.getState().setSelectedNode(sampleDataResourceTokenCollection),
|
|
children: [
|
|
{
|
|
label: "Items",
|
|
},
|
|
],
|
|
},
|
|
],
|
|
};
|
|
setRoot(updatedSampleTree);
|
|
}
|
|
}, [sampleDataResourceTokenCollection]);
|
|
|
|
return <TreeComponent className="dataResourceTree" rootNode={root || { label: "Sample data not initialized." }} />;
|
|
};
|