@twreporter/redux
Version:
redux actions and reducers for twreporter website
152 lines (143 loc) • 5.55 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.getUserFootprints = getUserFootprints;
exports.setUserFootprint = setUserFootprint;
var _axios = _interopRequireDefault(require("axios"));
var _apiConfig = _interopRequireDefault(require("../constants/api-config"));
var _apiEndpoints = _interopRequireDefault(require("../constants/api-endpoints"));
var _reduxStateFieldNames = _interopRequireDefault(require("../constants/redux-state-field-names"));
var _actionTypes = _interopRequireDefault(require("../constants/action-types"));
var _url = require("../utils/url");
var _errorActionCreators = _interopRequireDefault(require("./error-action-creators"));
var _get = _interopRequireDefault(require("lodash/get"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
// constants
// lodash
var _ = {
get: _get["default"]
};
var apiTimeout = _apiConfig["default"].timeout;
/**
* @typedef {Object} RequestAction
* @property {string} type - The type of action
* @property {string} payload.method - The HTTP request method
* @property {string} payload.url - The target to send request
* @property {Object} payload.body - The request body with POST, PUT, DELETE, or PATCH request
* @property {Object} payload.headers - The request header
*/
/**
* @typedef {Object} SuccessAction
* @property {string} type - The type of action
* @property {string} payload
* @property {Object} payload.data - Response data
* @property {string} payload.statusCode - Response status code
*/
/**
* @param {Object} axiosResponse
* @param {string} actionType
* @returns {SuccessAction}
*/
function buildSuccessActionFromRes(axiosResponse, actionType) {
return {
type: actionType,
payload: {
data: _.get(axiosResponse, 'data'),
statusCode: _.get(axiosResponse, 'status')
}
};
}
/**
* @typedef {Object} FailAction
* @property {string} type - Action error type
* @property {string} payload
* @property {string} payload.statusCode - Response status code
* @property {string} payload.message - Error message
* @property {object} payload.error - Error object
*/
/**
* get user's footprints
* @param {string} jwt - access_token granted for the user
* @param {number} userID - id of user
* @param {number} offset - the offset of the request
* @param {number} limit - max amount of records per fetch
* @returns {Function} - function will be executed in Redux Thunk middleware
*/
function getUserFootprints(jwt, userID) {
var offset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
var limit = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10;
/**
* @param {Function} dispatch - Redux store dispatch function
* @param {Function} getState - Redux store getState function
* @return {Promise} resolve with success action or reject with fail action
*/
return function (dispatch, getState) {
var state = getState();
var apiOrigin = _.get(state, [_reduxStateFieldNames["default"].origins, 'api']);
var url = (0, _url.formURL)(apiOrigin, "/v2/".concat(_apiEndpoints["default"].users, "/").concat(userID, "/analytics/reading-footprint"), {
limit: limit,
offset: offset
});
dispatch({
type: _actionTypes["default"].footprints.read.request,
url: url
});
var axiosConfig = {
timeout: apiTimeout,
headers: {
Authorization: "Bearer ".concat(jwt)
}
};
return _axios["default"].get(url, axiosConfig).then(function (res) {
var successAction = buildSuccessActionFromRes(res, _actionTypes["default"].footprints.read.success);
dispatch(successAction);
return successAction;
})["catch"](function (error) {
var failAction = _errorActionCreators["default"].axios(error, _actionTypes["default"].footprints.read.failure);
dispatch(failAction);
return Promise.reject(failAction);
});
};
}
/**
* update user footprint by post_id
* @param {string} jwt - access_token granted for the user
* @param {number} userID - id of user
* @param {string} postID - id of post
* @returns - function will be executed in Redux Thunk middleware
*/
function setUserFootprint(jwt, userID, postID) {
/**
* @param {Function} dispatch - Redux store dispatch function
* @param {Function} getState - Redux store getState function
* @return {Promise} resolve with success action or reject with fail action
*/
return function (dispatch, getState) {
var state = getState();
var apiOrigin = _.get(state, [_reduxStateFieldNames["default"].origins, 'api']);
var url = (0, _url.formURL)(apiOrigin, "/v2/".concat(_apiEndpoints["default"].users, "/").concat(userID, "/analytics/reading-footprint"));
dispatch({
type: _actionTypes["default"].footprints.update.request,
url: url
});
var axiosConfig = {
timeout: apiTimeout,
headers: {
Authorization: "Bearer ".concat(jwt)
}
};
var body = {
post_id: postID
};
return _axios["default"].post(url, body, axiosConfig).then(function (res) {
var successAction = buildSuccessActionFromRes(res, _actionTypes["default"].footprints.update.success);
dispatch(successAction);
return successAction;
})["catch"](function (error) {
var failAction = _errorActionCreators["default"].axios(error, _actionTypes["default"].footprints.update.failure);
dispatch(failAction);
return Promise.reject(failAction);
});
};
}