Пытаюсь получить актуальный state через getState(), при этом знаю, что state был изменен, а мне возвращаются не обновленные данные
вот что в файле store
export function initializeStore(initialState = baseState) {
return createStore(
mainReducer,
initialState,
composeWithDevTools(applyMiddleware(thunk))
);
}
export const baseReducer = (state = baseState, action) => {
switch (action.type) {
case TEST: {
return {...state, isTest: true};
}
case UPDATE_TOKEN: {
return {...state, userAuthToken: action.payload};
}
case "SET_PROJECT_DATA": {
return state = {
...state,
[action.payload.name]: action.payload.value
};
}
case "SET_PROJECT_DATA_ARRAY": {
action.payload.forEach(function (item) {
if (typeof item === "object") {
const keys = Object.keys(item);
keys.forEach((key) => state = {
...state,
[key]: item[key]
});
}
});
}
case "CLEAR_PROJECT_ERRORS": {
return state = {...state, [action.payload.name]: ""};
}
default:
return state;
}
};
файл js
export const submitStepOne = () => async (dispatch, getState) => {
const registerData = {
a: 1
};
try {
const responseA = await a(registerData);
dispatch(setData("newUser", responseA.data));
} catch (error) {
dispatch(setData("error", error));
}
// пытаюсь получить стор, возвращает старый
setTimeout(() => console.log(getState().base), 1000);
if (!getState().base.projectError) {
Router.push("/registration/two");
}
};