diff --git a/app/client/src/workers/Evaluation/handlers/evalTree.ts b/app/client/src/workers/Evaluation/handlers/evalTree.ts index 74430a9b6b..a511317bb7 100644 --- a/app/client/src/workers/Evaluation/handlers/evalTree.ts +++ b/app/client/src/workers/Evaluation/handlers/evalTree.ts @@ -27,7 +27,7 @@ import { asyncJsFunctionInDataFields } from "../JSObject/asyncJSFunctionBoundToD import type { LintTreeSagaRequestData } from "workers/Linting/types"; import { WorkerMessenger } from "../fns/utils/Messenger"; import { MAIN_THREAD_ACTION } from "@appsmith/workers/Evaluation/evalWorkerActions"; -export let replayMap: Record>; +export let replayMap: Record> | undefined; export let dataTreeEvaluator: DataTreeEvaluator | undefined; export const CANVAS = "canvas"; @@ -112,7 +112,7 @@ export default function (request: EvalWorkerSyncRequest) { allActionValidationConfig, ); } - if (shouldReplay) { + if (shouldReplay && replayMap) { replayMap[CANVAS]?.update({ widgets, theme }); } dataTreeEvaluator = new DataTreeEvaluator( @@ -169,7 +169,7 @@ export default function (request: EvalWorkerSyncRequest) { ); } isCreateFirstTree = false; - if (shouldReplay) { + if (shouldReplay && replayMap) { replayMap[CANVAS]?.update({ widgets, theme }); } const setupUpdateTreeResponse = dataTreeEvaluator.setupUpdateTree( @@ -231,7 +231,7 @@ export default function (request: EvalWorkerSyncRequest) { errors = dataTreeEvaluator.errors; dataTreeEvaluator.clearErrors(); logs = dataTreeEvaluator.logs; - if (shouldReplay) { + if (shouldReplay && replayMap) { if (replayMap[CANVAS]?.logs) logs = logs.concat(replayMap[CANVAS]?.logs); replayMap[CANVAS]?.clearLogs(); } diff --git a/app/client/src/workers/Evaluation/handlers/replay.ts b/app/client/src/workers/Evaluation/handlers/replay.ts index 79ff639740..33aafdd322 100644 --- a/app/client/src/workers/Evaluation/handlers/replay.ts +++ b/app/client/src/workers/Evaluation/handlers/replay.ts @@ -5,6 +5,7 @@ import { CANVAS, replayMap } from "./evalTree"; export function undo(request: EvalWorkerSyncRequest) { const { data } = request; const { entityId } = data; + if (!replayMap) return; if (!replayMap[entityId || CANVAS]) return; const replayResult = replayMap[entityId || CANVAS].replay("UNDO"); replayMap[entityId || CANVAS].clearLogs(); @@ -14,6 +15,7 @@ export function undo(request: EvalWorkerSyncRequest) { export function redo(request: EvalWorkerSyncRequest) { const { data } = request; const { entityId } = data; + if (!replayMap) return; if (!replayMap[entityId ?? CANVAS]) return; const replayResult = replayMap[entityId ?? CANVAS].replay("REDO"); replayMap[entityId ?? CANVAS].clearLogs(); @@ -23,6 +25,7 @@ export function redo(request: EvalWorkerSyncRequest) { export function updateReplayObject(request: EvalWorkerSyncRequest) { const { data } = request; const { entity, entityId, entityType } = data; + if (!replayMap) return false; const replayObject = replayMap[entityId]; if (replayObject) { replayObject.update(entity);