UNPKG

@twreporter/redux

Version:

redux actions and reducers for twreporter website

152 lines (143 loc) 5.55 kB
"use strict"; 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); }); }; }