PromucFlow_constructor/app/client/src/sagas/SnapshotSagas.ts
rahulramesha 801c4f3cae
chore: Change to Call fetch snapshot API call only from edit mode (#25342)
## Description
This PR contains changes to call fetch snapshot API only in Edit mode

Fixes #24715 

#### Type of change
- Chore (housekeeping or task changes that don't impact user perception)

## Testing

#### How Has This Been Tested?
- [ ] Manual

#### Issues raised during DP testing
> Link issues raised during DP testing for better visiblity and tracking
(copy link from comments dropped on this PR)
>
>
>
## Checklist:
#### Dev activity
- [ ] My code follows the style guidelines of this project
- [ ] I have performed a self-review of my own code
- [ ] I have commented my code, particularly in hard-to-understand areas
- [ ] I have made corresponding changes to the documentation
- [ ] My changes generate no new warnings
- [ ] I have added tests that prove my fix is effective or that my
feature works
- [ ] New and existing unit tests pass locally with my changes
- [ ] PR is being merged under a feature flag


#### QA activity:
- [ ] [Speedbreak
features](https://github.com/appsmithorg/TestSmith/wiki/Guidelines-for-test-plans#speedbreakers-)
have been covered
- [ ] Test plan covers all impacted features and [areas of
interest](https://github.com/appsmithorg/TestSmith/wiki/Guidelines-for-test-plans#areas-of-interest-)
- [ ] Test plan has been peer reviewed by project stakeholders and other
QA members
- [ ] Manually tested functionality on DP
- [ ] We had an implementation alignment call with stakeholders post QA
Round 2
- [ ] Cypress test cases have been added and approved by SDET/manual QA
- [ ] Added `Test Plan Approved` label after Cypress tests were reviewed
- [ ] Added `Test Plan Approved` label after JUnit tests were reviewed
2023-07-19 10:52:07 +05:30

206 lines
5.7 KiB
TypeScript

import {
setLayoutConversionStateAction,
updateSnapshotDetails,
} from "actions/autoLayoutActions";
import type { ApiResponse } from "api/ApiResponses";
import ApplicationApi from "@appsmith/api/ApplicationApi";
import type { PageDefaultMeta } from "@appsmith/api/ApplicationApi";
import { ReduxActionTypes } from "@appsmith/constants/ReduxActionConstants";
import log from "loglevel";
import type { SnapShotDetails } from "reducers/uiReducers/layoutConversionReducer";
import { CONVERSION_STATES } from "reducers/uiReducers/layoutConversionReducer";
import { all, call, put, select, takeLatest } from "redux-saga/effects";
import {
getAppPositioningType,
getCurrentApplicationId,
} from "selectors/editorSelectors";
import { getLogToSentryFromResponse } from "utils/helpers";
import { validateResponse } from "./ErrorSagas";
import { updateApplicationLayoutType } from "./AutoLayoutUpdateSagas";
import { AppPositioningTypes } from "reducers/entityReducers/pageListReducer";
import AnalyticsUtil from "utils/AnalyticsUtil";
//Saga to create application snapshot
export function* createSnapshotSaga() {
let response: ApiResponse | undefined;
try {
const applicationId: string = yield select(getCurrentApplicationId);
response = yield ApplicationApi.createApplicationSnapShot({
applicationId,
});
const isValidResponse: boolean = yield validateResponse(
response,
false,
getLogToSentryFromResponse(response),
);
if (isValidResponse) {
return true;
}
} catch (error) {
throw error;
}
}
//Saga to fetch application snapshot
export function* fetchSnapshotSaga() {
let response: ApiResponse<SnapShotDetails> | undefined;
try {
const applicationId: string = yield select(getCurrentApplicationId);
response = yield ApplicationApi.getSnapShotDetails({
applicationId,
});
const isValidResponse: boolean = yield validateResponse(
response,
false,
getLogToSentryFromResponse(response),
);
if (isValidResponse) {
const snapShotDetails = response?.data;
return snapShotDetails;
}
} catch (error) {
if (getLogToSentryFromResponse(response)) {
log.error(error);
throw error;
}
}
}
//Saga to restore application snapshot
function* restoreApplicationFromSnapshotSaga() {
let response: ApiResponse<any> | undefined;
let appId = "";
try {
appId = yield select(getCurrentApplicationId);
AnalyticsUtil.logEvent("RESTORE_SNAPSHOT", {
appId,
});
const applicationId: string = yield select(getCurrentApplicationId);
response = yield ApplicationApi.restoreApplicationFromSnapshot({
applicationId,
});
const currentAppPositioningType: AppPositioningTypes = yield select(
getAppPositioningType,
);
const isValidResponse: boolean = yield validateResponse(
response,
false,
getLogToSentryFromResponse(response),
);
// update the pages list temporarily with incomplete data.
if (response?.data?.pages) {
yield put({
type: ReduxActionTypes.FETCH_PAGE_LIST_SUCCESS,
payload: {
pages: response.data.pages.map((page: PageDefaultMeta) => ({
pageId: page.id,
isDefault: page.isDefault,
})),
applicationId,
},
});
}
//update layout positioning type from
yield call(
updateApplicationLayoutType,
currentAppPositioningType === AppPositioningTypes.FIXED
? AppPositioningTypes.AUTO
: AppPositioningTypes.FIXED,
);
if (isValidResponse) {
//update conversion form state to success
yield put(
setLayoutConversionStateAction(CONVERSION_STATES.COMPLETED_SUCCESS),
);
}
} catch (e: any) {
let error: Error = e;
if (error) {
error.message = `Layout conversion error - while restoring snapshot: ${error.message}`;
} else {
error = new Error("Layout conversion error - while restoring snapshot");
}
log.error(error);
//update conversion form state to error
yield put(
setLayoutConversionStateAction(CONVERSION_STATES.COMPLETED_ERROR, error),
);
AnalyticsUtil.logEvent("CONVERSION_FAILURE", {
flow: "RESTORE_SNAPSHOT",
appId,
});
}
}
//Saga to delete application snapshot
export function* deleteApplicationSnapshotSaga() {
let response: ApiResponse | undefined;
try {
const applicationId: string = yield select(getCurrentApplicationId);
response = yield ApplicationApi.deleteApplicationSnapShot({
applicationId,
});
const isValidResponse: boolean = yield validateResponse(
response,
false,
getLogToSentryFromResponse(response),
);
if (isValidResponse) {
yield put(updateSnapshotDetails(undefined));
}
} catch (error) {
log.error(error);
throw error;
}
}
//Saga to update snapshot details by fetching info from backend
function* updateSnapshotDetailsSaga() {
try {
const snapShotDetails: { updatedTime: Date } | undefined = yield call(
fetchSnapshotSaga,
);
yield put(
updateSnapshotDetails(
snapShotDetails && snapShotDetails.updatedTime
? { lastUpdatedTime: snapShotDetails.updatedTime?.toString() }
: undefined,
),
);
} catch (error) {
throw error;
}
}
export default function* snapshotSagas() {
yield all([
takeLatest(
ReduxActionTypes.RESTORE_SNAPSHOT,
restoreApplicationFromSnapshotSaga,
),
takeLatest(
[
ReduxActionTypes.FETCH_LAYOUT_SNAPSHOT_DETAILS,
ReduxActionTypes.START_CONVERSION_FLOW,
],
updateSnapshotDetailsSaga,
),
takeLatest(ReduxActionTypes.DELETE_SNAPSHOT, deleteApplicationSnapshotSaga),
]);
}