Files
Dwinzo_Demo/app/src/components/layout/scenes/MainScene.tsx

222 lines
8.6 KiB
TypeScript
Raw Normal View History

2025-06-12 17:35:42 +05:30
import React, { useEffect } from "react";
2025-06-10 15:28:23 +05:30
import {
useLoadingProgress,
2025-06-12 09:31:51 +05:30
useRenameModeStore,
2025-06-10 15:28:23 +05:30
useSaveVersion,
useSelectedAssets,
useSelectedComment,
2025-06-12 09:31:51 +05:30
useSelectedFloorItem,
2025-06-10 15:28:23 +05:30
useSocketStore,
useWidgetSubOption,
} from "../../../store/builder/store";
import useModuleStore, { useThreeDStore } from "../../../store/useModuleStore";
import { usePlayButtonStore } from "../../../store/usePlayButtonStore";
import { useSelectedZoneStore } from "../../../store/visualization/useZoneStore";
import { useFloatingWidget } from "../../../store/visualization/useDroppedObjectsStore";
import { useSelectedUserStore } from "../../../store/collaboration/useCollabStore";
import KeyPressListener from "../../../utils/shortcutkeys/handleShortcutKeys";
import LoadingPage from "../../templates/LoadingPage";
import ModuleToggle from "../../ui/ModuleToggle";
import SideBarLeft from "../sidebarLeft/SideBarLeft";
import SideBarRight from "../sidebarRight/SideBarRight";
import RealTimeVisulization from "../../../modules/visualization/RealTimeVisulization";
import MarketPlace from "../../../modules/market/MarketPlace";
import Tools from "../../ui/Tools";
import SimulationPlayer from "../../ui/simulation/simulationPlayer";
import ControlsPlayer from "../controls/ControlsPlayer";
import SelectFloorPlan from "../../temporary/SelectFloorPlan";
import { createHandleDrop } from "../../../modules/visualization/functions/handleUiDrop";
import Scene from "../../../modules/scene/scene";
import {
useComparisonProduct,
useMainProduct,
} from "../../../store/simulation/useSimulationStore";
import { useProductContext } from "../../../modules/simulation/products/productContext";
import RegularDropDown from "../../ui/inputs/RegularDropDown";
2025-06-12 09:31:51 +05:30
import RenameTooltip from "../../ui/features/RenameTooltip";
import { setAssetsApi } from "../../../services/factoryBuilder/asset/floorAsset/setAssetsApi";
2025-06-12 09:31:51 +05:30
import { useParams } from "react-router-dom";
2025-06-23 09:37:53 +05:30
import { useSceneContext } from "../../../modules/scene/sceneContext";
import { useVersionHistoryStore } from "../../../store/builder/useVersionHistoryStore";
import { useVersionContext } from "../../../modules/builder/version/versionContext";
import VersionSaved from "../sidebarRight/versionHisory/VersionSaved";
import Footer from "../../footer/Footer";
import ThreadChat from "../../ui/collaboration/ThreadChat";
2025-06-10 15:28:23 +05:30
function MainScene() {
const { setMainProduct } = useMainProduct();
const { selectedProductStore } = useProductContext();
const { selectedProduct } = selectedProductStore();
2025-06-12 17:35:42 +05:30
const { isVersionSaved, setIsVersionSaved } = useSaveVersion();
2025-06-10 15:28:23 +05:30
const { activeModule } = useModuleStore();
const { selectedUser } = useSelectedUserStore();
const { loadingProgress } = useLoadingProgress();
const { toggleThreeD } = useThreeDStore();
const { isPlaying } = usePlayButtonStore();
const { widgetSubOption } = useWidgetSubOption();
const { visualizationSocket } = useSocketStore();
const { selectedZone } = useSelectedZoneStore();
const { setFloatingWidget } = useFloatingWidget();
2025-06-12 17:35:42 +05:30
const { clearComparisonProduct } = useComparisonProduct();
2025-06-12 09:31:51 +05:30
const { selectedFloorItem, setSelectedFloorItem } = useSelectedFloorItem();
const { selectedAssets, setSelectedAssets } = useSelectedAssets();
2025-06-23 09:37:53 +05:30
const { assetStore, productStore } = useSceneContext();
const { products } = productStore();
const { setName } = assetStore();
2025-06-12 09:31:51 +05:30
const { projectId } = useParams()
const { isRenameMode, setIsRenameMode } = useRenameModeStore();
2025-06-23 09:37:53 +05:30
const { versionHistory } = useVersionHistoryStore();
const { selectedVersionStore } = useVersionContext();
const { selectedVersion, setSelectedVersion } = selectedVersionStore();
const { selectedComment, commentPositionState } = useSelectedComment();
2025-06-12 17:35:42 +05:30
useEffect(() => {
if (activeModule !== 'simulation') {
clearComparisonProduct();
setIsVersionSaved(false);
}
2025-08-22 14:01:44 +05:30
}, [activeModule, clearComparisonProduct, setIsVersionSaved])
2025-06-12 17:35:42 +05:30
2025-06-23 09:37:53 +05:30
useEffect(() => {
if (versionHistory.length > 0) {
setSelectedVersion(versionHistory[0])
}
2025-08-22 14:01:44 +05:30
}, [setSelectedVersion, versionHistory])
2025-06-23 09:37:53 +05:30
const handleSelectVersion = (option: string) => {
const version = versionHistory.find((version) => version.versionName === option);
if (version) {
setSelectedVersion(version);
}
};
const handleSelectProduct = (option: string) => {
2025-06-10 15:28:23 +05:30
const product = products.find((product) => product.productName === option);
if (product) {
setMainProduct(product.productUuid, product.productName);
}
};
2025-06-23 09:37:53 +05:30
2025-06-12 09:31:51 +05:30
const handleObjectRename = async (newName: string) => {
2025-06-12 17:35:42 +05:30
if (!projectId) return
if (selectedFloorItem) {
console.log('selectedFloorItem.userData.modelUuid: ', selectedFloorItem.userData.modelUuid);
console.log(' newName: ', newName);
console.log('projectId: ', projectId);
setAssetsApi({
modelUuid: selectedFloorItem.userData.modelUuid,
modelName: newName,
projectId,
versionId: selectedVersion?.versionId || ''
}).then(() => {
selectedFloorItem.userData = {
...selectedFloorItem.userData,
modelName: newName
};
setSelectedFloorItem(selectedFloorItem);
setIsRenameMode(false);
setName(selectedFloorItem.userData.modelUuid, newName);
})
} else if (selectedAssets.length === 1) {
setAssetsApi({
modelUuid: selectedAssets[0].userData.modelUuid,
modelName: newName,
projectId,
versionId: selectedVersion?.versionId || ''
}).then(() => {
selectedAssets[0].userData = {
...selectedAssets[0].userData,
modelName: newName
};
setSelectedAssets(selectedAssets);
setIsRenameMode(false);
setName(selectedAssets[0].userData.modelUuid, newName);
})
}
2025-06-12 09:31:51 +05:30
}
2025-06-10 15:28:23 +05:30
return (
<>
{!selectedUser && (
<>
<KeyPressListener />
2025-08-22 14:01:44 +05:30
{loadingProgress > 0 && <LoadingPage progress={loadingProgress} />}
2025-06-10 15:28:23 +05:30
{!isPlaying && (
<>
2025-06-23 09:37:53 +05:30
{toggleThreeD && !isVersionSaved && <ModuleToggle />}
2025-06-10 15:28:23 +05:30
<SideBarLeft />
<SideBarRight />
</>
)}
<RealTimeVisulization />
{activeModule === "market" && <MarketPlace />}
{activeModule !== "market" && !isPlaying && !isVersionSaved && (
<Tools />
)}
2025-06-12 17:35:42 +05:30
{(isPlaying) &&
2025-06-10 15:28:23 +05:30
activeModule === "simulation" &&
2025-08-22 14:01:44 +05:30
loadingProgress === 0 && <SimulationPlayer />}
2025-06-12 17:35:42 +05:30
{(isPlaying) &&
2025-06-10 15:28:23 +05:30
activeModule !== "simulation" && <ControlsPlayer />}
{isRenameMode && (selectedFloorItem?.userData.modelName || selectedAssets.length === 1) && <RenameTooltip name={selectedFloorItem?.userData.modelName || selectedAssets[0].userData.modelName} onSubmit={handleObjectRename} />}
2025-06-10 15:28:23 +05:30
{/* remove this later */}
{activeModule === "builder" && !toggleThreeD && <SelectFloorPlan />}
</>
)}
<div
className="scene-container"
id="work-space-three-d-canvas"
style={{
height: isPlaying || activeModule !== "visualization" ? "100vh" : "",
width: isPlaying || activeModule !== "visualization" ? "100vw" : "",
left: isPlaying || activeModule !== "visualization" ? "0%" : "",
borderRadius:
isPlaying || activeModule !== "visualization" ? "" : "6px",
}}
role="application"
onDrop={(event) =>
createHandleDrop({
widgetSubOption,
visualizationSocket,
selectedZone,
setFloatingWidget,
event,
2025-06-23 09:37:53 +05:30
projectId,
versionId: selectedVersion?.versionId || '',
2025-06-10 15:28:23 +05:30
})
}
onDragOver={(event) => event.preventDefault()}
>
2025-08-22 14:01:44 +05:30
<Scene layout="Main Layout" />
2025-06-10 15:28:23 +05:30
</div>
2025-06-23 09:37:53 +05:30
{selectedProduct && selectedVersion && isVersionSaved && !isPlaying && activeModule === "simulation" && (
2025-06-10 15:28:23 +05:30
<div className="selectLayout-wrapper">
2025-06-23 09:37:53 +05:30
<RegularDropDown
header={selectedVersion.versionName}
options={versionHistory.map((v) => v.versionName)} // Pass layout names as options
onSelect={handleSelectVersion}
search={false}
/>
<br />
2025-06-10 15:28:23 +05:30
<RegularDropDown
header={selectedProduct.productName}
options={products.map((l) => l.productName)} // Pass layout names as options
2025-06-23 09:37:53 +05:30
onSelect={handleSelectProduct}
2025-06-10 15:28:23 +05:30
search={false}
/>
</div>
)}
2025-06-23 09:37:53 +05:30
{activeModule !== "market" && !selectedUser && <Footer />}
<VersionSaved />
{(commentPositionState !== null || selectedComment !== null) && <ThreadChat />}
2025-06-23 09:37:53 +05:30
2025-06-10 15:28:23 +05:30
</>
);
}
export default MainScene;