нужно в redux-persist реализовать корпус REHYDRATE?

Я работаю над доказательством концепции в react-native, и я использую redux-persist. Согласно тому, что я прочитал, состояния автоматически назначаются в версии 5, однако мне не удалось восстановить состояние без случая REHYDRATE.

Мой редуктор:

import {ADD_USER} from '../constants/actionTypes';
import { REHYDRATE } from 'redux-persist';


const initialState = {
    userName: null,
    fetching: false
};

const userReducer = (state = initialState, action) => {
    let copied = Object.assign({}, state);
    switch (action.type){
        case ADD_USER:
            copied.userName = action.payload;
            break;
        case REHYDRATE:
            //console.log('Payload desde el reducer ', action.payload);fsdffdsdsfsdfsdf
            copied = action.payload.userReducer;
            break;
        default:
            break;
    }

    return copied;
};

export default userReducer;

Мой configureStore

const persistConfig = {
    key: 'root',
    storage,
    stateReconciler: autoMergeLevel2,
};

function logger({ getState }) {
    return (next) => (action) => {
        let returnValue = next(action)
        return returnValue
    }
}

const persistedReducer = persistCombineReducers(persistConfig, {userReducer});

export default () => {
    let store = createStore(persistedReducer, undefined, applyMiddleware(logger));
    let persistor = persistStore(store, null, () => {
        Alert.alert(
            'Fucking state',
            JSON.stringify(store.getState()),
            [
                {text: 'OK', onPress: () => console.log('OK Pressed')},
            ],
            { cancelable: false }
        );
    });
    return { store, persistor }
}

person Matias Aguirre Luco    schedule 24.12.2018    source источник


Ответы (1)


Моя проблема заключалась в том, что я возвращал состояние в конце метода вместо того, чтобы возвращать его в каждом случае переключения, и это наверняка нарушило автоматическую регидратацию. Смена редуктора возвращает мою проблему.

Код редуктора был таким:

const initialState = {
    userName: null,
    fetching: false
};

const userReducer = (state = initialState, action) => {
    switch (action.type){
        case ADD_USER:{
            let copied = Object.assign({}, state);
            copied.userName = action.payload;
            return copied;
        }
        default:
            return state;
    }
};

export default userReducer;
person Matias Aguirre Luco    schedule 25.12.2018
comment
это странно, но твой пост спас мне день - person 44kksharma; 28.05.2019