store loading state with redux.
$ npm install redux-saga-loading --save
import { createStore, combineReducers, applyMiddleware } from 'redux';
import { createReduxSagaLoading } from 'redux-saga-loading'
const loading = createReduxSagaLoading()
const rootReducer = combineReducers({
...reducers,
...loading.reduxReducers
});
export const store = createStore(
rootReducer,
applyMiddleware(thunk, sagaMiddleware)
)
import { call, put } from "redux-saga/effects";
import { api } from 'apis'
import { startLoading, stopLoading } from 'redux-saga-loading'
function* list(action: any) {
try {
yield startLoading('users', 'rooms')
const users = yield call(api.getUsers);
const rooms = yield call(api.getRooms);
yield put({ type: "SET_USERS", users });
yield put({ type: "SET_ROOMS", rooms });
} catch (error) { } finally {
yield stopLoading('users', 'rooms')
// or yield stopAllLoading()
}
}
Then we can access loading state from store.
opts.namespace
: property key on global state, type String, Defaultloading
loading: {
models: {
users: false,
...
},
}
Create reducers for loading.
Type: Object
opts.namespace
: property key on global state, type String, Default loading
ex. { namespace: 'myLoading' }
Set start state of models.
Type: string
Array
List of name for models.
Set start state of models.
Type: string
Array
List of name for models.
Start all loading state. Should make sure that the models are existing in reducer.
Stop all loading state.