2025-09-06 14:05:29 +05:30
|
|
|
import { useEffect } from "react";
|
|
|
|
|
import { useActionHandler } from "../actions/useActionHandler";
|
|
|
|
|
import { usePlayButtonStore, useResetButtonStore } from "../../../store/usePlayButtonStore";
|
|
|
|
|
import { determineExecutionOrder } from "./functions/determineExecutionOrder";
|
|
|
|
|
import { useProductContext } from "../products/productContext";
|
|
|
|
|
import { useSceneContext } from "../../scene/sceneContext";
|
|
|
|
|
import SimulationHandler from "./SimulationHandler";
|
|
|
|
|
import { getSimulationData, saveSimulationData } from "../../../components/layout/scenes/functions/simulationStorage";
|
|
|
|
|
import { useParams } from "react-router-dom";
|
|
|
|
|
import { useVersionContext } from "../../builder/version/versionContext";
|
|
|
|
|
import { version } from "os";
|
|
|
|
|
import { get } from "http";
|
|
|
|
|
import { useSimulationManager } from "../../../store/rough/useSimulationManagerStore";
|
2025-06-10 15:28:23 +05:30
|
|
|
|
|
|
|
|
function Simulator() {
|
|
|
|
|
const { selectedProductStore } = useProductContext();
|
2025-06-23 09:37:53 +05:30
|
|
|
const { productStore } = useSceneContext();
|
|
|
|
|
const { products, getProductById } = productStore();
|
2025-06-10 15:28:23 +05:30
|
|
|
const { handleAction } = useActionHandler();
|
|
|
|
|
const { selectedProduct } = selectedProductStore();
|
|
|
|
|
const { isPlaying } = usePlayButtonStore();
|
|
|
|
|
const { isReset } = useResetButtonStore();
|
2025-09-06 14:05:29 +05:30
|
|
|
const { projectId } = useParams();
|
|
|
|
|
const { selectedVersionStore } = useVersionContext();
|
|
|
|
|
const { selectedVersion } = selectedVersionStore();
|
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]);
|
2025-08-22 09:52:02 +05:30
|
|
|
|
2025-09-06 14:05:29 +05:30
|
|
|
executionOrder.forEach((action) => {
|
2025-06-10 15:28:23 +05:30
|
|
|
handleAction(action);
|
|
|
|
|
});
|
|
|
|
|
}, [products, isPlaying, isReset, selectedProduct]);
|
2025-09-06 14:05:29 +05:30
|
|
|
useEffect(() => {
|
|
|
|
|
if (!projectId || !selectedVersion || !selectedProduct?.productUuid) return;
|
|
|
|
|
const fetchSimulateData = async () => {
|
|
|
|
|
const getData = await getSimulationData(projectId, selectedVersion.versionId, selectedProduct?.productUuid);
|
|
|
|
|
const product = getProductById(selectedProduct.productUuid);
|
|
|
|
|
if (!product) return;
|
|
|
|
|
const products: productsSchema = [product];
|
|
|
|
|
const getSimulate = getData?.data;
|
|
|
|
|
if (getData && getSimulate && getSimulate.productTimestamp === products[0]?.timestamp) {
|
|
|
|
|
return;
|
|
|
|
|
} else {
|
|
|
|
|
//call create API
|
|
|
|
|
const data = {
|
|
|
|
|
projectId: projectId,
|
|
|
|
|
versionId: selectedVersion.versionId,
|
|
|
|
|
productUuid: selectedProduct.productUuid,
|
|
|
|
|
simulateData: useSimulationManager.getState().getProductById(projectId, selectedVersion?.versionId, selectedProduct.productUuid)?.simulateData,
|
|
|
|
|
};
|
|
|
|
|
const simulations = await saveSimulationData(data);
|
|
|
|
|
console.log("simulations: ", simulations);
|
|
|
|
|
echo.log("Simulation data saved successfully");
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
fetchSimulateData();
|
|
|
|
|
}, []);
|
2025-06-10 15:28:23 +05:30
|
|
|
return (
|
|
|
|
|
<>
|
2025-09-04 17:26:18 +05:30
|
|
|
{/* <simulationHandler/> */}
|
|
|
|
|
<SimulationHandler />
|
2025-06-10 15:28:23 +05:30
|
|
|
</>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2025-09-06 14:05:29 +05:30
|
|
|
export default Simulator;
|