Files
Dwinzo_Demo/app/src/modules/simulation/simulator/simulator.tsx

66 lines
2.9 KiB
TypeScript
Raw Normal View History

import { useEffect } from "react";
import { useActionHandler } from "../actions/useActionHandler";
import { usePlayButtonStore, useResetButtonStore } from "../../../store/ui/usePlayButtonStore";
import { determineExecutionOrder } from "./functions/determineExecutionOrder";
import { useSceneContext } from "../../scene/sceneContext";
2025-09-09 16:07:07 +05:30
import SimulationHandler from "./simulationHandler";
import { useParams } from "react-router-dom";
import { useSimulationManager } from "../../../store/rough/useSimulationManagerStore";
2025-09-09 09:39:59 +05:30
import { getSimulationDataApi } from "../../../services/simulation/comparison/getSimulationDataApi";
2025-09-09 16:07:07 +05:30
import { getProductApi } from "../../../services/simulation/products/getProductApi";
import { useIsComparing } from "../../../store/builder/store";
2025-06-10 15:28:23 +05:30
function Simulator() {
2025-09-06 18:19:02 +05:30
const { productStore, versionStore } = useSceneContext();
const { products, getProductById, selectedProduct } = productStore();
2025-06-10 15:28:23 +05:30
const { handleAction } = useActionHandler();
const { isPlaying } = usePlayButtonStore();
const { isReset } = useResetButtonStore();
const { projectId } = useParams();
const { selectedVersion } = versionStore();
2025-09-09 16:07:07 +05:30
const { setIsComparing } = useIsComparing();
const { addSimulationRecords } = useSimulationManager();
2025-06-10 15:28:23 +05:30
useEffect(() => {
if (!isPlaying || isReset || !selectedProduct.productUuid) return;
const product = getProductById(selectedProduct.productUuid);
if (!product) return;
const executionOrder = determineExecutionOrder([product]);
executionOrder.forEach((action) => {
2025-06-10 15:28:23 +05:30
handleAction(action);
});
2025-09-09 09:39:59 +05:30
// eslint-disable-next-line react-hooks/exhaustive-deps
2025-06-10 15:28:23 +05:30
}, [products, isPlaying, isReset, selectedProduct]);
useEffect(() => {
if (!projectId || !selectedVersion || !selectedProduct?.productUuid) return;
2025-09-09 16:07:07 +05:30
getSimulationDataApi(projectId, selectedVersion.versionId, selectedProduct?.productUuid).then((getData) => {
getProductApi(selectedProduct.productUuid, projectId, selectedVersion.versionId).then((product) => {
if (!product) return;
const getSimulate = getData?.data;
2025-09-09 09:39:59 +05:30
2025-09-09 16:07:07 +05:30
if (getData.message !== "Simulated data not found" && getSimulate && getSimulate.productTimestamp === product?.timestamp) {
addSimulationRecords(projectId, selectedVersion?.versionId || "", selectedProduct?.productUuid || "", getSimulate.data);
echo.warn("Simulation data is up to date");
return;
} else {
setIsComparing(false);
echo.warn("Please run the simulation before comparing.");
}
});
});
2025-09-09 09:39:59 +05:30
// eslint-disable-next-line react-hooks/exhaustive-deps
2025-09-09 16:07:07 +05:30
}, [selectedProduct, projectId]);
2025-06-10 15:28:23 +05:30
return (
<>
2025-09-04 17:26:18 +05:30
<SimulationHandler />
2025-06-10 15:28:23 +05:30
</>
);
}
export default Simulator;