2017-11-06 17:03:20 +01:00
|
|
|
import { LOCATION_CHANGE } from 'react-router-redux';
|
|
|
|
import { takeLatest, put, fork, take, cancel } from 'redux-saga/effects';
|
|
|
|
|
|
|
|
import { fetchDataSucceeded } from './actions';
|
|
|
|
import { FETCH_DATA } from './constants';
|
|
|
|
import data from './data.json';
|
|
|
|
|
|
|
|
export function* dataFetch(action) {
|
|
|
|
try {
|
|
|
|
const response = data[action.endPoint];
|
|
|
|
|
|
|
|
yield put(fetchDataSucceeded(response));
|
|
|
|
|
|
|
|
} catch(err) {
|
|
|
|
window.Strapi.notification.error('An error occured');
|
|
|
|
}
|
|
|
|
}
|
2017-11-06 11:14:43 +01:00
|
|
|
|
|
|
|
// Individual exports for testing
|
|
|
|
export function* defaultSaga() {
|
2017-11-06 17:03:20 +01:00
|
|
|
const loadDataWatcher = yield fork(takeLatest, FETCH_DATA, dataFetch);
|
|
|
|
|
|
|
|
yield take(LOCATION_CHANGE);
|
|
|
|
yield cancel(loadDataWatcher);
|
2017-11-06 11:14:43 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// All sagas to be loaded
|
|
|
|
export default defaultSaga;
|