79 lines
1.7 KiB
JavaScript
Raw Normal View History

2017-01-23 20:04:12 +01:00
import { takeLatest } from 'redux-saga';
2017-04-11 11:34:59 +02:00
import { put, select, fork, call } from 'redux-saga/effects';
import request from 'utils/request';
2017-01-23 20:04:12 +01:00
import {
2017-04-11 11:34:59 +02:00
loadedRecord,
loadedCount,
2017-01-23 20:04:12 +01:00
} from './actions';
import {
2017-04-11 11:34:59 +02:00
LOAD_RECORDS,
LOAD_COUNT,
2017-01-23 20:04:12 +01:00
} from './constants';
import {
makeSelectCurrentModelName,
2017-04-11 11:34:59 +02:00
makeSelectLimitPerPage,
makeSelectCurrentPage,
} from './selectors';
2017-01-23 20:04:12 +01:00
export function* getRecords() {
const currentModel = yield select(makeSelectCurrentModelName());
2017-04-11 11:34:59 +02:00
const limitPerPage = yield select(makeSelectLimitPerPage());
const currentPage = yield select(makeSelectCurrentPage());
// Calculate the number of values to be skip
const skip = (currentPage - 1) * limitPerPage;
// Init `params` object
const params = {
skip,
limit: limitPerPage,
};
try {
const requestURL = `http://localhost:1337/content-manager/explorer/${currentModel}`;
// Call our request helper (see 'utils/request')
const data = yield call(request, requestURL, {
method: 'GET',
params,
});
yield put(loadedRecord(data));
} catch (err) {
console.error(err);
}
}
export function* getCount() {
const currentModel = yield select(makeSelectCurrentModelName());
2017-01-23 20:04:12 +01:00
2017-01-28 18:11:54 +01:00
try {
const opts = {
method: 'GET',
mode: 'cors',
cache: 'default'
};
2017-04-11 11:34:59 +02:00
const response = yield fetch(`http://localhost:1337/content-manager/explorer/${currentModel}/count`, opts);
2017-01-28 18:11:54 +01:00
const data = yield response.json();
2017-04-11 11:34:59 +02:00
yield put(loadedCount(data.count));
2017-01-28 18:11:54 +01:00
} catch (err) {
console.error(err);
}
2017-01-23 20:04:12 +01:00
}
// Individual exports for testing
export function* defaultSaga() {
2017-04-11 11:34:59 +02:00
yield fork(takeLatest, LOAD_RECORDS, getRecords);
yield fork(takeLatest, LOAD_COUNT, getCount);
}
// All sagas to be loaded
export default [
defaultSaga,
];