2020-07-06 13:35:31 +00:00
|
|
|
import { take } from "lodash";
|
|
|
|
|
import { all, select, put, takeEvery } from "redux-saga/effects";
|
2020-05-05 07:50:30 +00:00
|
|
|
import {
|
|
|
|
|
ReduxAction,
|
|
|
|
|
ReduxActionTypes,
|
|
|
|
|
ReduxActionWithMeta,
|
|
|
|
|
ReduxFormActionTypes,
|
|
|
|
|
} from "constants/ReduxActionConstants";
|
|
|
|
|
import { getFormData } from "selectors/formSelectors";
|
2020-07-07 08:07:37 +00:00
|
|
|
import { QUERY_EDITOR_FORM_NAME } from "constants/forms";
|
2020-05-05 07:50:30 +00:00
|
|
|
import history from "utils/history";
|
|
|
|
|
import {
|
|
|
|
|
QUERIES_EDITOR_URL,
|
|
|
|
|
QUERIES_EDITOR_ID_URL,
|
|
|
|
|
APPLICATIONS_URL,
|
|
|
|
|
} from "constants/routes";
|
|
|
|
|
import {
|
|
|
|
|
getCurrentApplicationId,
|
|
|
|
|
getCurrentPageId,
|
|
|
|
|
} from "selectors/editorSelectors";
|
2020-07-06 13:35:31 +00:00
|
|
|
import { initialize } from "redux-form";
|
2020-05-05 07:50:30 +00:00
|
|
|
import { AppState } from "reducers";
|
2020-07-06 13:35:31 +00:00
|
|
|
import { changeQuery } from "actions/queryPaneActions";
|
|
|
|
|
import { getAction } from "selectors/entitiesSelector";
|
2020-07-03 08:58:58 +00:00
|
|
|
import { RestAction } from "entities/Action";
|
2020-07-06 13:35:31 +00:00
|
|
|
import { setActionProperty } from "actions/actionActions";
|
2020-05-05 07:50:30 +00:00
|
|
|
|
|
|
|
|
const getActions = (state: AppState) =>
|
|
|
|
|
state.entities.actions.map(a => a.config);
|
|
|
|
|
|
|
|
|
|
const getLastUsedAction = (state: AppState) => state.ui.queryPane.lastUsed;
|
|
|
|
|
|
2020-06-20 05:29:30 +00:00
|
|
|
const getQueryCreationStatus = (state: AppState) =>
|
|
|
|
|
state.ui.queryPane.isCreating;
|
|
|
|
|
|
2020-05-05 07:50:30 +00:00
|
|
|
function* initQueryPaneSaga(
|
|
|
|
|
actionPayload: ReduxAction<{
|
|
|
|
|
pluginType: string;
|
|
|
|
|
id?: string;
|
|
|
|
|
}>,
|
|
|
|
|
) {
|
|
|
|
|
let actions = yield select(getActions);
|
|
|
|
|
while (!actions.length) {
|
|
|
|
|
yield take(ReduxActionTypes.FETCH_ACTIONS_SUCCESS);
|
|
|
|
|
actions = yield select(getActions);
|
|
|
|
|
}
|
|
|
|
|
const urlId = actionPayload.payload.id;
|
|
|
|
|
const lastUsedId = yield select(getLastUsedAction);
|
2020-06-20 05:29:30 +00:00
|
|
|
const isCreating = yield select(getQueryCreationStatus);
|
2020-05-05 07:50:30 +00:00
|
|
|
|
|
|
|
|
let id = "";
|
|
|
|
|
if (urlId) {
|
|
|
|
|
id = urlId;
|
|
|
|
|
} else if (lastUsedId) {
|
|
|
|
|
id = lastUsedId;
|
|
|
|
|
}
|
|
|
|
|
|
2020-06-20 05:29:30 +00:00
|
|
|
if (isCreating) return;
|
|
|
|
|
|
2020-07-07 08:07:37 +00:00
|
|
|
yield put(changeQuery(id));
|
2020-05-05 07:50:30 +00:00
|
|
|
}
|
|
|
|
|
|
2020-07-07 08:07:37 +00:00
|
|
|
function* changeQuerySaga(actionPayload: ReduxAction<{ id: string }>) {
|
2020-05-05 07:50:30 +00:00
|
|
|
const { id } = actionPayload.payload;
|
|
|
|
|
// Typescript says Element does not have blur function but it does;
|
|
|
|
|
document.activeElement &&
|
|
|
|
|
"blur" in document.activeElement &&
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/ban-ts-ignore
|
|
|
|
|
// @ts-ignore
|
|
|
|
|
document.activeElement.blur();
|
|
|
|
|
|
|
|
|
|
const applicationId = yield select(getCurrentApplicationId);
|
|
|
|
|
const pageId = yield select(getCurrentPageId);
|
|
|
|
|
if (!applicationId || !pageId) {
|
|
|
|
|
history.push(APPLICATIONS_URL);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
const action = yield select(getAction, id);
|
|
|
|
|
if (!action) {
|
|
|
|
|
history.push(QUERIES_EDITOR_URL(applicationId, pageId));
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const URL = QUERIES_EDITOR_ID_URL(applicationId, pageId, id);
|
2020-07-03 08:58:58 +00:00
|
|
|
yield put(initialize(QUERY_EDITOR_FORM_NAME, action));
|
2020-05-05 07:50:30 +00:00
|
|
|
history.push(URL);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function* formValueChangeSaga(
|
|
|
|
|
actionPayload: ReduxActionWithMeta<string, { field: string; form: string }>,
|
|
|
|
|
) {
|
2020-07-06 13:35:31 +00:00
|
|
|
const { form, field } = actionPayload.meta;
|
|
|
|
|
if (field === "dynamicBindingPathList" || field === "name") return;
|
2020-05-05 07:50:30 +00:00
|
|
|
if (form !== QUERY_EDITOR_FORM_NAME) return;
|
2020-07-06 13:35:31 +00:00
|
|
|
const { values } = yield select(getFormData, QUERY_EDITOR_FORM_NAME);
|
|
|
|
|
yield put(
|
|
|
|
|
setActionProperty({
|
|
|
|
|
actionId: values.id,
|
|
|
|
|
propertyName: field,
|
|
|
|
|
value: actionPayload.payload,
|
|
|
|
|
}),
|
|
|
|
|
);
|
2020-05-05 07:50:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function* handleQueryCreatedSaga(actionPayload: ReduxAction<RestAction>) {
|
|
|
|
|
const { id, pluginType } = actionPayload.payload;
|
|
|
|
|
const action = yield select(getAction, id);
|
|
|
|
|
const data = { ...action };
|
|
|
|
|
if (pluginType === "DB") {
|
|
|
|
|
yield put(initialize(QUERY_EDITOR_FORM_NAME, data));
|
|
|
|
|
const applicationId = yield select(getCurrentApplicationId);
|
|
|
|
|
const pageId = yield select(getCurrentPageId);
|
2020-07-06 05:38:39 +00:00
|
|
|
history.replace(
|
|
|
|
|
QUERIES_EDITOR_ID_URL(applicationId, pageId, id, {
|
|
|
|
|
new: true,
|
|
|
|
|
}),
|
|
|
|
|
);
|
2020-05-05 07:50:30 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default function* root() {
|
|
|
|
|
yield all([
|
|
|
|
|
takeEvery(ReduxActionTypes.CREATE_ACTION_SUCCESS, handleQueryCreatedSaga),
|
|
|
|
|
takeEvery(ReduxActionTypes.QUERY_PANE_CHANGE, changeQuerySaga),
|
|
|
|
|
takeEvery(ReduxActionTypes.INIT_QUERY_PANE, initQueryPaneSaga),
|
|
|
|
|
// Intercepting the redux-form change actionType
|
|
|
|
|
takeEvery(ReduxFormActionTypes.VALUE_CHANGE, formValueChangeSaga),
|
|
|
|
|
takeEvery(ReduxFormActionTypes.ARRAY_REMOVE, formValueChangeSaga),
|
|
|
|
|
]);
|
|
|
|
|
}
|